diff --git a/Bank-Beispiel/Konten.ser b/Bank-Beispiel/Konten.ser index 1b57d53..edadb8a 100644 Binary files a/Bank-Beispiel/Konten.ser and b/Bank-Beispiel/Konten.ser differ diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java new file mode 100644 index 0000000..1acfd96 --- /dev/null +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java @@ -0,0 +1,24 @@ +package de.hs_mannheim.informatik.bank.domain; + +public class Girokonto extends Konto { + + public Girokonto(String inhaber) { + super(inhaber); + } + + public boolean ueberweise(Girokonto ziel, long betrag, String zweck, String datum) { + if (super.getKontostand() - betrag >= 0) { + this.kontoAbheben(this, betrag, datum, zweck, "(-)", super.getInhaber()); + ziel.kontoEinzahlen(ziel, betrag, datum, zweck, "(+)", super.getInhaber()); + + return true; + } + return false; + } + + @Override + public String toString() { + return "Giro-" + super.toString(); + } + +} diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java index a4ef59d..13d3ba5 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java @@ -8,6 +8,7 @@ import java.util.ArrayList; import java.util.Collection; import de.hs_mannheim.informatik.bank.domain.Bank; +import de.hs_mannheim.informatik.bank.domain.Girokonto; import de.hs_mannheim.informatik.bank.domain.Konto; import de.hs_mannheim.informatik.bank.persistence.PersistenceService; @@ -19,10 +20,14 @@ public class Banksystem { this.bank = new Bank(bankname); } - public int kontoAnlegen(String name) { - Konto k = new Konto(name); - bank.addKonto(k); + public int kontoAnlegen(String name, int auswahl) { + Konto k; + if (auswahl == 1) + k = new Konto(name); + else + k = new Girokonto(name); + bank.addKonto(k); return k.getKontonummer(); } @@ -73,6 +78,23 @@ public class Banksystem { return betrag_aktuell; } + public boolean ueberweisungBeauftragen(int startkonto, int zielkonto, String betrag, String zweck) { + Konto start = bank.getKonto(startkonto); + Konto ziel = bank.getKonto(zielkonto); + + zweck = verwendungszweckAnpassen(zweck); + betrag = betragMitKomma(betrag); + long betrag_long = Long.parseLong(betrag.replace(".", "")); + String datum = getDatum(); + + if (start instanceof Girokonto && ziel instanceof Girokonto) { + ((Girokonto)start).ueberweise((Girokonto)ziel, betrag_long, zweck, datum); + return true; + } + + return false; + } + public String getDatum() { DateTimeFormatter zeitformat = DateTimeFormatter.ofPattern("dd.MM.yyyy"); LocalDateTime zeit = LocalDateTime.now(); @@ -91,6 +113,16 @@ public class Banksystem { return betrag; } + private String verwendungszweckAnpassen(String zweck) { + int laenge = zweck.length(); + int laengeNochDazu = 22 - laenge; + String leerzeilen = ""; + for (int i = 0; i < laengeNochDazu; i++) { + leerzeilen = leerzeilen + " "; + } + return zweck + leerzeilen; + } + private String kontostandMitKomma(Konto k) { // Betrag mit 2 Nachkommastellen für den User anzeigen lassen StringBuilder standKomma = new StringBuilder(Long.toString(k.getKontostand())); diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java index 381c3ca..0a854b3 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java @@ -12,21 +12,21 @@ class BanksystemTest { @Test void kontoEinzahlenMitKommatest() { Banksystem bs = new Banksystem("Testbank"); - int kontonr = bs.kontoAnlegen("User"); + int kontonr = bs.kontoAnlegen("User", 1); assertEquals("42.50", bs.kontoEinzahlen("42.50", kontonr)); } @Test void kontoEinzahlenOhneKommatest() { Banksystem bs = new Banksystem("Testbank2"); - int kontonr = bs.kontoAnlegen("User2"); + int kontonr = bs.kontoAnlegen("User2", 1); assertEquals("50.00", bs.kontoEinzahlen("50", kontonr)); } @Test void kontoAbhebenMitKommatest() { Banksystem bs = new Banksystem("Testbank"); - int kontonr = bs.kontoAnlegen("User"); + int kontonr = bs.kontoAnlegen("User", 1); bs.kontoEinzahlen("100", kontonr); assertEquals("50.00", bs.kontoAbheben("50.00", kontonr)); } @@ -34,7 +34,7 @@ class BanksystemTest { @Test void kontoAbhebenOhneKommatest() { Banksystem bs = new Banksystem("Testbank2"); - int kontonr = bs.kontoAnlegen("User2"); + int kontonr = bs.kontoAnlegen("User2", 1); bs.kontoEinzahlen("100", kontonr); assertEquals("50.00", bs.kontoAbheben("50", kontonr)); } @@ -42,7 +42,7 @@ class BanksystemTest { @Test void kontoStandTest() { Banksystem bs = new Banksystem("Testbank"); - int kontonr = bs.kontoAnlegen("User"); + int kontonr = bs.kontoAnlegen("User", 1); bs.kontoEinzahlen("100", kontonr); assertEquals("100.00", bs.kontoStand(kontonr)); } @@ -50,14 +50,14 @@ class BanksystemTest { @Test void kontoStandWennNull() { Banksystem bs = new Banksystem("Testbank"); - int kontonr = bs.kontoAnlegen("User"); + int kontonr = bs.kontoAnlegen("User", 1); assertEquals("0.00", bs.kontoStand(kontonr)); } @Test void getKontenlisteTest() { Banksystem bs = new Banksystem("Testbank"); - int kontonr = bs.kontoAnlegen("User"); + int kontonr = bs.kontoAnlegen("User", 1); String[] konten = new String[1]; konten = bs.getKontenliste(); @@ -74,7 +74,7 @@ class BanksystemTest { @Test void getInhaberTest() { Banksystem bs = new Banksystem("Test"); - int kontonr = bs.kontoAnlegen("User"); + int kontonr = bs.kontoAnlegen("User", 1); assertEquals("User", bs.getInhaber(kontonr)); } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java index 5bdfeec..9f84158 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java @@ -28,6 +28,7 @@ public class UI { System.out.println("4 -> Kontostand"); System.out.println("5 -> Abheben"); System.out.println("6 -> Kontoauszug"); + System.out.println("7 -> Überweisung"); System.out.println("9 -> Beenden"); System.out.println(); @@ -42,6 +43,7 @@ public class UI { case 4: kontoStand(); break; case 5: kontoAbheben(); break; case 6: kontoAuszug(); break; + case 7: ueberweisungBeauftragen(); break; case 9: break mainloop; } } @@ -65,8 +67,11 @@ public class UI { private void kontoAnlegen() { System.out.println("Bitte den Namen des Kontoinhabers angeben: "); String name = sc.nextLine(); + + System.out.println("Möchten Sie ein Sparkonto (1) oder ein Girokonto (2) anlegen?"); + int auswahl = Integer.parseInt(sc.nextLine()); - int kontonummer = bs.kontoAnlegen(name); + int kontonummer = bs.kontoAnlegen(name, auswahl); System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt."); } @@ -123,5 +128,23 @@ public class UI { System.out.println("-----------------------------------------------------------------------"); System.out.println("Aktueller Kontostand:\t\t\t\t\t " + bs.kontoStand(kontonr) + "€"); } + + private void ueberweisungBeauftragen() { + System.out.print("Bitte die Kontonummer des Ausgangskontos der Überweisung eingeben: "); + int startkonto = Integer.parseInt(sc.nextLine()); + + System.out.print("Bitte die Kontonummmer für das Zielkonto der Überweisung eingeben: "); + int zielkonto = Integer.parseInt(sc.nextLine()); + + System.out.print("Bitte den gewünschten Überweisungsbetrag eingeben: "); + String betrag = sc.nextLine(); + + System.out.print("Bitte den Verwendungszweck eingeben: "); + String verwendungszweck = sc.nextLine(); + + boolean erfolgreich = bs.ueberweisungBeauftragen(startkonto, zielkonto, betrag, verwendungszweck); + + System.out.println("Überweisung" + ( (!erfolgreich) ? " nicht" : "") + " erfolgreich ausgeführt."); + } }