From 09b40fe62e0708da40c482fffdb07fe360c75a26 Mon Sep 17 00:00:00 2001 From: Alper2402 <2121675@stud.hs-mannheim.de> Date: Mon, 24 Oct 2022 10:51:05 +0200 Subject: [PATCH] =?UTF-8?q?Girokonto=20hinzugef=C3=BCgt?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Bank-Beispiel/Konten.ser | Bin 725 -> 2387 bytes .../informatik/bank/domain/Girokonto.java | 24 +++++++++++ .../informatik/bank/facade/Banksystem.java | 38 ++++++++++++++++-- .../bank/facade/BanksystemTest.java | 16 ++++---- .../de/hs_mannheim/informatik/bank/ui/UI.java | 25 +++++++++++- 5 files changed, 91 insertions(+), 12 deletions(-) create mode 100644 Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java diff --git a/Bank-Beispiel/Konten.ser b/Bank-Beispiel/Konten.ser index 1b57d5399a7386b7f636bf5fb4fc1f192ca69a6c..edadb8a2b4c079bd579527b214206c18c57ea1f5 100644 GIT binary patch literal 2387 zcmbtWO=}ZD7@mCWrWQr5RZl|kq!c&1+r*C+l%gWlC~ED|%A}cYHpx!v?yT8HEfy5K ziASOS0|kG82cd#D1rfxXM?cyh;LUkwzuVNN*u&77c|V?c-sgQcuhx;|*yun5-@}T_ z%$71~+jy~JI?P-CeB{Lk{4$3!Qz-A4UE(bugyc>hR_-)fBTC)5V_{0`#IzKX&bMs~ zGqb5wF>NZfwuMcqTxnC*ekPmm>tBa%XHk9%$<(zhVqfN|8K$)gDwwp6tHfq#r~*ie zEliE#G_y@=OjOX`CWNSx4l!J65X#U&-wXg3Bft}YFZY9^Ln!mkWk{NFh^;wy(ULeT z2;>Ehd~65E!?cYXPoMvB7e8i^R6#jxGYFfjpxxM=XErtr!XFTv$yEYJ!A`1S=33#V z+aYsJvGEod${ia$4jY-Ff~KmfqN)rHYG)KpRdiL?89H>)q+MKZ@t2QaYh-$^j$4e_ z;#C9SIvDs%C0!|}z2Rn$ZwaYRgsEgrA5%)@jhQB0XUk0g4K)QIul0Cn-|3}tz>}`_ z$x|x1e46_So>Tt4(|dxxEEm>KAtJPTJrI^22`eLnm5GV=YdXr1Tn|u zKV@Dr?Y3x&hx=E)<-1?jI6x1o4M2YhpqbZi0-$3N(6D#Gav-i~DJ8x>kcKZEUR~j$ z?-0}B>U6N{7`$&GIFBfEIR`8!p1$uEaoFnHgjaxN=b`ctDnt_Y5hRW|FKx?t?C&>6 z8hFBg7jMHRZ*@ZZc7e|IT}G0BzM^zqsNbSc*`wcsLX|{lIFy8Y=_HUb;U^5*Pu_lN>pT+|s%EBEE z!sCWa1gY?(kzv3nz+?PRL!5+SxwVjLj?(38_Cn}2j`gmti!5OQ3;by2>| z@GLxINkoN{)U=5RT}q2MLJ0;5@&zJpE9;vffvKNed;mjJNee!J={hAWqlyZiA*1SZR|Nfbl?gUiRTJn=mLm(gFj5@+fF delta 118 zcmcaCbd`025jRsg3j+fKQ*jZ4_T-7oY7>)7<(b~vmN2k}7N-^&78f$q0i_ujSi#Cz ofy#_Q$~Ma~wlW%5fTfuj7?@vz6#)sTMkBaJ2CznkiVBE50C`&&m;e9( 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."); + } }