forked from hummel/Bank-System
added Kontoauszug feature.
parent
6e1a803522
commit
60cc1b67aa
|
@ -0,0 +1,3 @@
|
||||||
|
# Default ignored files
|
||||||
|
/shelf/
|
||||||
|
/workspace.xml
|
|
@ -0,0 +1,9 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<module type="JAVA_MODULE" version="4">
|
||||||
|
<component name="NewModuleRootManager" inherit-compiler-output="true">
|
||||||
|
<exclude-output />
|
||||||
|
<content url="file://$MODULE_DIR$" />
|
||||||
|
<orderEntry type="inheritedJdk" />
|
||||||
|
<orderEntry type="sourceFolder" forTests="false" />
|
||||||
|
</component>
|
||||||
|
</module>
|
|
@ -0,0 +1,17 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="junit.jupiter" type="repository">
|
||||||
|
<properties maven-id="org.junit.jupiter:junit-jupiter:5.8.2" />
|
||||||
|
<CLASSES>
|
||||||
|
<root url="jar://$MAVEN_REPOSITORY$/org/junit/jupiter/junit-jupiter/5.8.2/junit-jupiter-5.8.2.jar!/" />
|
||||||
|
<root url="jar://$MAVEN_REPOSITORY$/org/junit/jupiter/junit-jupiter-api/5.8.2/junit-jupiter-api-5.8.2.jar!/" />
|
||||||
|
<root url="jar://$MAVEN_REPOSITORY$/org/opentest4j/opentest4j/1.2.0/opentest4j-1.2.0.jar!/" />
|
||||||
|
<root url="jar://$MAVEN_REPOSITORY$/org/junit/platform/junit-platform-commons/1.8.2/junit-platform-commons-1.8.2.jar!/" />
|
||||||
|
<root url="jar://$MAVEN_REPOSITORY$/org/apiguardian/apiguardian-api/1.1.2/apiguardian-api-1.1.2.jar!/" />
|
||||||
|
<root url="jar://$MAVEN_REPOSITORY$/org/junit/jupiter/junit-jupiter-params/5.8.2/junit-jupiter-params-5.8.2.jar!/" />
|
||||||
|
<root url="jar://$MAVEN_REPOSITORY$/org/junit/jupiter/junit-jupiter-engine/5.8.2/junit-jupiter-engine-5.8.2.jar!/" />
|
||||||
|
<root url="jar://$MAVEN_REPOSITORY$/org/junit/platform/junit-platform-engine/1.8.2/junit-platform-engine-1.8.2.jar!/" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES />
|
||||||
|
</library>
|
||||||
|
</component>
|
|
@ -0,0 +1,4 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="ProjectRootManager" version="2" project-jdk-name="17" project-jdk-type="JavaSDK" />
|
||||||
|
</project>
|
|
@ -0,0 +1,8 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="ProjectModuleManager">
|
||||||
|
<modules>
|
||||||
|
<module fileurl="file://$PROJECT_DIR$/.idea/Bank-System-Fork.iml" filepath="$PROJECT_DIR$/.idea/Bank-System-Fork.iml" />
|
||||||
|
</modules>
|
||||||
|
</component>
|
||||||
|
</project>
|
|
@ -0,0 +1,6 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="VcsDirectoryMappings">
|
||||||
|
<mapping directory="" vcs="Git" />
|
||||||
|
</component>
|
||||||
|
</project>
|
|
@ -1,8 +1,10 @@
|
||||||
package de.hs_mannheim.informatik.bank.domain;
|
package de.hs_mannheim.informatik.bank.domain;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
public class Konto {
|
public class Konto {
|
||||||
private static int kontozähler = 0;
|
private static int kontozähler = 0;
|
||||||
|
private ArrayList<String> kontoauszug = new ArrayList<>();
|
||||||
private int nummer;
|
private int nummer;
|
||||||
private long stand = 0;
|
private long stand = 0;
|
||||||
private String inhaber;
|
private String inhaber;
|
||||||
|
@ -24,6 +26,14 @@ public class Konto {
|
||||||
this.stand += value;
|
this.stand += value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void remGuthaben(int value) { this.stand -= value; }
|
||||||
|
|
||||||
|
public void addKontoBewegung(String kontoBewegung) {
|
||||||
|
kontoauszug.add(kontoBewegung);
|
||||||
|
}
|
||||||
|
public ArrayList<String> getKontoauszug() {
|
||||||
|
return this.kontoauszug;
|
||||||
|
}
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "Konto [nummer=" + nummer + ", inhaber=" + inhaber + "]";
|
return "Konto [nummer=" + nummer + ", inhaber=" + inhaber + "]";
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
package de.hs_mannheim.informatik.bank.facade;
|
package de.hs_mannheim.informatik.bank.facade;
|
||||||
|
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
import java.time.format.DateTimeFormatter;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
|
||||||
import de.hs_mannheim.informatik.bank.domain.Bank;
|
import de.hs_mannheim.informatik.bank.domain.Bank;
|
||||||
|
@ -44,9 +47,56 @@ public class Banksystem {
|
||||||
return konto;
|
return konto;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
System.out.println("Die angegebene Kontonummer existiert nicht, bitte versuchen Sie es erneut!");
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String[] getKontoauszug(Konto konto) {
|
||||||
|
ArrayList<String> kontoauszug = konto.getKontoauszug();
|
||||||
|
String[] auszugArray = new String[kontoauszug.size()];
|
||||||
|
int i = 0;
|
||||||
|
for (String auszug : kontoauszug) {
|
||||||
|
auszugArray[i] = auszug;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
return auszugArray;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addGuthaben(Konto konto, int value) {
|
||||||
|
konto.addGuthaben(value);
|
||||||
|
String bew = createKontoBewegung(konto, value, "+");
|
||||||
|
konto.addKontoBewegung(bew);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public long getGuthaben(Konto konto) {
|
||||||
|
return konto.getGuthaben();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String createKontoBewegung(Konto konto, int value, String direction) {
|
||||||
|
String kontoBewegung = "";
|
||||||
|
|
||||||
|
DateTimeFormatter dtf = DateTimeFormatter.ofPattern("dd/MM/yyyy HH:mm");
|
||||||
|
String date = dtf.format(LocalDateTime.now());
|
||||||
|
|
||||||
|
if (direction.equals("+")) {
|
||||||
|
kontoBewegung = date + " | " + konto.toString() + " | +" + value + "€";
|
||||||
|
} else {
|
||||||
|
kontoBewegung = date + " | " + konto.toString() + " | -" + value + "€";
|
||||||
|
}
|
||||||
|
|
||||||
|
return kontoBewegung;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean geldAbheben(Konto konto, int value) {
|
||||||
|
if (value <= konto.getGuthaben()) {
|
||||||
|
konto.remGuthaben(value);
|
||||||
|
String bew = createKontoBewegung(konto, value, "-");
|
||||||
|
konto.addKontoBewegung(bew);
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package de.hs_mannheim.informatik.bank.ui;
|
package de.hs_mannheim.informatik.bank.ui;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Scanner;
|
import java.util.Scanner;
|
||||||
|
|
||||||
|
@ -28,7 +29,9 @@ public class UI {
|
||||||
System.out.println("1 -> Konten anzeigen");
|
System.out.println("1 -> Konten anzeigen");
|
||||||
System.out.println("2 -> Konto anlegen");
|
System.out.println("2 -> Konto anlegen");
|
||||||
System.out.println("3 -> Geld einzahlen");
|
System.out.println("3 -> Geld einzahlen");
|
||||||
System.out.println("4 -> Guthaben ausgeben");
|
System.out.println("4 -> Geld auszahlen");
|
||||||
|
System.out.println("5 -> Guthaben ausgeben");
|
||||||
|
System.out.println("6 -> Kontoauszug ausgeben");
|
||||||
System.out.println("9 -> Beenden");
|
System.out.println("9 -> Beenden");
|
||||||
System.out.println();
|
System.out.println();
|
||||||
|
|
||||||
|
@ -46,7 +49,9 @@ public class UI {
|
||||||
case 1 -> kontenAnzeigen();
|
case 1 -> kontenAnzeigen();
|
||||||
case 2 -> kontoAnlegen();
|
case 2 -> kontoAnlegen();
|
||||||
case 3 -> kontoAufladen();
|
case 3 -> kontoAufladen();
|
||||||
case 4 -> guthabenAusgeben();
|
case 4 -> geldAuszahlen();
|
||||||
|
case 5 -> guthabenAusgeben();
|
||||||
|
case 6 -> kontoauszug();
|
||||||
case 9 -> {
|
case 9 -> {
|
||||||
break mainloop;
|
break mainloop;
|
||||||
}
|
}
|
||||||
|
@ -61,13 +66,32 @@ public class UI {
|
||||||
Konto konto = selectKonto();
|
Konto konto = selectKonto();
|
||||||
|
|
||||||
System.out.println("\nIhr aktuelles Guthaben ist: ");
|
System.out.println("\nIhr aktuelles Guthaben ist: ");
|
||||||
System.out.print(konto.getGuthaben());
|
System.out.print(bs.getGuthaben(konto));
|
||||||
System.out.println("€");
|
System.out.println("€");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void geldAuszahlen() {
|
||||||
|
Konto konto = selectKonto();
|
||||||
|
|
||||||
|
System.out.println("Wieviel Euro möchten Sie abheben?");
|
||||||
|
|
||||||
|
int input = getInt();
|
||||||
|
|
||||||
|
Boolean auszahlung = bs.geldAbheben(konto, input);
|
||||||
|
|
||||||
|
if (!auszahlung) {
|
||||||
|
System.out.println("Ihr Guthaben reicht für diese Auszahlung nicht mehr aus!");
|
||||||
|
System.out.println("Ihr Kontostand ist aktuell " + bs.getGuthaben(konto) + "€ und Sie wollten " + input + "€ auszahlen lassen!");
|
||||||
|
} else {
|
||||||
|
System.out.println("Sie haben sich erfolgreich " + input + "€ ausgezahlt!");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
private void kontoAufladen() {
|
private void kontoAufladen() {
|
||||||
Konto konto = selectKonto();
|
Konto konto = selectKonto();
|
||||||
|
|
||||||
|
if (konto != null) {
|
||||||
System.out.println("Wieviel möchten sie aufladen? (nur ganze Beträge)!");
|
System.out.println("Wieviel möchten sie aufladen? (nur ganze Beträge)!");
|
||||||
System.out.print("> ");
|
System.out.print("> ");
|
||||||
|
|
||||||
|
@ -81,7 +105,7 @@ public class UI {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (input != 0) {
|
if (input != 0) {
|
||||||
konto.addGuthaben(input);
|
bs.addGuthaben(konto, input);
|
||||||
System.out.println("\n" + input + "€ wurden aufgeladen!");
|
System.out.println("\n" + input + "€ wurden aufgeladen!");
|
||||||
System.out.println("Ihr aktueller Kontostand beträgt " + konto.getGuthaben() + "€");
|
System.out.println("Ihr aktueller Kontostand beträgt " + konto.getGuthaben() + "€");
|
||||||
System.out.println("Drücken Sie ENTER um zum Hauptmenu zurück zu kehren!");
|
System.out.println("Drücken Sie ENTER um zum Hauptmenu zurück zu kehren!");
|
||||||
|
@ -89,6 +113,8 @@ public class UI {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
private Konto selectKonto() {
|
private Konto selectKonto() {
|
||||||
System.out.println("Bitte geben Sie die Kontonummer ihres Kontos an: ");
|
System.out.println("Bitte geben Sie die Kontonummer ihres Kontos an: ");
|
||||||
|
|
||||||
|
@ -106,7 +132,7 @@ public class UI {
|
||||||
Konto konto = bs.getKonto(input);
|
Konto konto = bs.getKonto(input);
|
||||||
|
|
||||||
if (konto == null) {
|
if (konto == null) {
|
||||||
selectKonto();
|
System.out.println("Die angegebene Kontonummer existiert nicht!");
|
||||||
}
|
}
|
||||||
|
|
||||||
return konto;
|
return konto;
|
||||||
|
@ -126,6 +152,15 @@ public class UI {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void kontoauszug() {
|
||||||
|
Konto konto = selectKonto();
|
||||||
|
|
||||||
|
String[] kontoauszug = bs.getKontoauszug(konto);
|
||||||
|
for (String k : kontoauszug) {
|
||||||
|
System.out.println(k);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void kontoAnlegen() {
|
private void kontoAnlegen() {
|
||||||
System.out.println("Bitte den Namen des Kontoinhabers angeben: ");
|
System.out.println("Bitte den Namen des Kontoinhabers angeben: ");
|
||||||
String name = sc.nextLine();
|
String name = sc.nextLine();
|
||||||
|
@ -134,4 +169,15 @@ public class UI {
|
||||||
System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt.");
|
System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private int getInt() {
|
||||||
|
int input = 0;
|
||||||
|
try {
|
||||||
|
input = Integer.parseInt(sc.nextLine());
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Bitte geben Sie einen gültigen Betrag ein!");
|
||||||
|
kontoAufladen();
|
||||||
|
}
|
||||||
|
return input;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue