From e791696af80753e96c49c03294c96321297cbd1b Mon Sep 17 00:00:00 2001 From: informatikperson <62358979+informatikperson@users.noreply.github.com> Date: Tue, 25 Oct 2022 13:05:30 +0200 Subject: [PATCH] Hummels version integriert --- .../informatik/bank/domain/Bank.java | 28 +- .../informatik/bank/domain/Girokonto.java | 4 +- .../informatik/bank/domain/Konto.java | 8 +- .../informatik/bank/domain/KontoTest.java | 25 +- .../informatik/bank/domain/Kontobewegung.java | 28 ++ .../bank/domain/Kontobewegungen.java | 22 -- .../informatik/bank/facade/Banksystem.java | 110 ++---- .../bank/facade/BanksystemTest.java | 22 ++ .../de/hs_mannheim/informatik/bank/ui/UI.java | 352 +++++------------- 9 files changed, 232 insertions(+), 367 deletions(-) create mode 100644 Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Kontobewegung.java delete mode 100644 Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Kontobewegungen.java create mode 100644 Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java diff --git a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Bank.java b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Bank.java index 89e7601..27aeb58 100644 --- a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Bank.java +++ b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Bank.java @@ -1,21 +1,30 @@ package de.hs_mannheim.informatik.bank.domain; import java.io.Serializable; -import java.util.ArrayList; import java.util.Collection; import java.util.HashMap; -import java.util.List; -public class Bank implements Serializable{ +public class Bank implements Serializable { private String name; private HashMap konten = new HashMap<>(); + private int kontozähler; public Bank(String name) { this.name = name; + this.kontozähler = -1; } - public void addKonto(Konto k) { + public int addKonto(String name, int auswahl) { + Konto k; + + if (auswahl == 1) + k = new Konto(name, ++kontozähler); + else + k = new Girokonto(name, ++kontozähler); + konten.put(k.getKontonummer(), k); + + return k.getKontonummer(); } public String getName() { @@ -25,12 +34,9 @@ public class Bank implements Serializable{ public Collection getKontenliste() { return konten.values(); } - public List getAuszüge(int kontonummer){ - Konto konto = konten.get(kontonummer); - if (konto == null) { - return new ArrayList<>(); - } - return konto.getAuszüge(); - + + public Konto findeKonto(int kontonummer) { + return konten.get(kontonummer); } + } diff --git a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java index 9d143a7..0956f65 100644 --- a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java +++ b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java @@ -2,7 +2,8 @@ package de.hs_mannheim.informatik.bank.domain; import java.io.Serializable; -public class Girokonto extends Konto implements Serializable{ +public class Girokonto extends Konto implements Serializable { + public Girokonto(String inhaber, int kontozähler) { super(inhaber, kontozähler); } @@ -22,4 +23,5 @@ public class Girokonto extends Konto implements Serializable{ public String toString() { return "Giro-" + super.toString(); } + } diff --git a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Konto.java b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Konto.java index 63ab9ea..dd38d64 100644 --- a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Konto.java +++ b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Konto.java @@ -8,7 +8,7 @@ public class Konto implements Serializable { private long stand = 0; private String inhaber; - private ArrayList kontobewegungen; + private ArrayList kontobewegungen; public Konto(String inhaber, int kontozähler) { nummer = 1000 + kontozähler; @@ -37,14 +37,14 @@ public class Konto implements Serializable { public void einzahlen(long betrag, String zweck, String art, String auftraggeber) { stand += betrag; - kontobewegungen.add(new Kontobewegungen(betrag, zweck, art, auftraggeber)); + kontobewegungen.add(new Kontobewegung(betrag, zweck, art, auftraggeber)); } public boolean auszahlen(long betrag, String zweck, String art, String auftraggeber) { if (stand - betrag >= 0) { stand -= betrag; - kontobewegungen.add(new Kontobewegungen(betrag * -1, zweck, art, auftraggeber)); + kontobewegungen.add(new Kontobewegung(betrag * -1, zweck, art, auftraggeber)); return true; } @@ -56,7 +56,7 @@ public class Konto implements Serializable { String[] auflistung = new String[kontobewegungen.size()]; int i = 0; - for (Kontobewegungen kb : kontobewegungen) { + for (Kontobewegung kb : kontobewegungen) { auflistung[i++] = kb.toString(); } diff --git a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java index 8170c06..04e96ae 100644 --- a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java +++ b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java @@ -7,14 +7,29 @@ import org.junit.jupiter.api.Test; class KontoTest { @Test - void test() { - fail("Not yet implemented"); + void testKontoBasics() { + Konto k = new Konto("Müller", 0); + assertEquals("Müller", k.getInhaber()); + assertEquals(1000, k.getKontonummer()); + assertEquals(0, k.getKontostand()); } + @Test - void hilf() { - Konto konto = new Konto("hans"); - konto.getKontonummer(); + void testKontoEinUndAuszahlung() { + Konto k = new Konto("Müller", 0); + Konto k2 = new Konto("Mayer", 1); + assertEquals("Mayer", k2.getInhaber()); + assertNotEquals(k.getKontonummer(), k2.getKontonummer()); + + k2.einzahlen(100, "Test", "Einzahlung", "JUnit"); + assertEquals(100, k2.getKontostand()); + + assertTrue(k2.auszahlen(50, "Test", "Auszahlung", "JUnit")); + assertEquals(50, k2.getKontostand()); + + assertFalse(k2.auszahlen(500, "Test", "Auszahlung", "JUnit")); + assertEquals(50, k2.getKontostand()); } } diff --git a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Kontobewegung.java b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Kontobewegung.java new file mode 100644 index 0000000..d6b15dd --- /dev/null +++ b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Kontobewegung.java @@ -0,0 +1,28 @@ +package de.hs_mannheim.informatik.bank.domain; + +import java.io.Serializable; +import java.util.Date; + +public class Kontobewegung implements Serializable { + private long betrag; + private Date datum; + private String betreff; + private String art; + private String auftraggeber; + + public Kontobewegung(long betrag, String betreff, String art, String auftraggeber) { + this.betrag = betrag; + this.betreff = betreff; + this.art = art; + this.auftraggeber = auftraggeber; + + this.datum = new Date(); + } + + @Override + public String toString() { + return "Kontobewegung [betrag=" + betrag + ", datum=" + datum + ", betreff=" + betreff + ", art=" + art + + ", auftraggeber=" + auftraggeber + "]"; + } + +} diff --git a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Kontobewegungen.java b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Kontobewegungen.java deleted file mode 100644 index d5e38f6..0000000 --- a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/domain/Kontobewegungen.java +++ /dev/null @@ -1,22 +0,0 @@ -package de.hs_mannheim.informatik.bank.domain; - -import java.io.Serializable; -import java.util.Date; - -public class Kontobewegungen implements Serializable { - - private long kontostand; - private long betrag; - private Date date = new Date(); - private String auftraggeber; - - public Kontobewegungen(long kontozustand, long betrag, String auftraggeber) { - this.kontostand = kontostand; - this.betrag = betrag; - this.auftraggeber = auftraggeber; - } - @Override - public String toString() { - return "Datum: "+ date.toString()+ " , Kontostand: "+kontostand+ " , Betrag: " +(betrag<0? "-":"+") + betrag + " , "+ " Auftraggeber: " + auftraggeber; - } -} diff --git a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java index 1959137..44c757e 100644 --- a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java +++ b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java @@ -1,11 +1,10 @@ package de.hs_mannheim.informatik.bank.facade; import java.util.Collection; -import java.util.List; 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.domain.Kontobewegungen; import infrastruktur.Persistenz; public class Banksystem { @@ -15,16 +14,15 @@ public class Banksystem { if (Persistenz.sindDatenGespeichert(bankname)) this.bank = (Bank) Persistenz.ladeBankDaten(bankname); else - this.bank = new Bank(bankname); + this.bank = new Bank(bankname); } - public int kontoAnlegen(String name) throws Exception { - Konto k = new Konto(name); - bank.addKonto(k); + public int kontoAnlegen(String name, int auswahl) throws Exception { + int kontonummer = bank.addKonto(name, auswahl); Persistenz.speichereBankDaten(this.bank, bank.getName()); - return k.getKontonummer(); + return kontonummer; } public String[] getKontenliste() { @@ -33,7 +31,7 @@ public class Banksystem { int i = 0; for (Konto k : konten) { - liste[i++] = k.toString(); + liste[i++] = k.toString(); } return liste; @@ -43,82 +41,44 @@ public class Banksystem { return bank.getName(); } - public void kontoAufladen(String name, long aufzahlen) throws Exception { - Collection konten = bank.getKontenliste(); - for (Konto k : konten) { - String konto = k.toString(); - if (konto.contains(name)) { - k.addKontostand(name, aufzahlen); - Persistenz.speichereBankDaten(this.bank, bank.getName()); - } - } + public long geldEinzahlen(int kontonummer, long betrag) throws Exception { + Konto konto = bank.findeKonto(kontonummer); + konto.einzahlen(betrag, "Einzahlung am Schalter", "Einzahlung", konto.getInhaber()); - } - public void kontoAufladen(int nummer, long aufzahlen) throws Exception { - Collection konten = bank.getKontenliste(); - String num = Integer.toString(nummer); - for (Konto k : konten) { - String konto = k.toString(); - if (konto.contains(num)) { - k.addKontostand(k.getKontoinhaber(), aufzahlen); - Persistenz.speichereBankDaten(this.bank, bank.getName()); - } - } + Persistenz.speichereBankDaten(this.bank, bank.getName()); + + return konto.getKontostand(); } + public boolean geldAuszahlen(int kontonummer, long betrag) throws Exception { + Konto konto = bank.findeKonto(kontonummer); + + Persistenz.speichereBankDaten(this.bank, bank.getName()); - public boolean checkForInstance(String name) { - Collection konten = bank.getKontenliste(); - for (Konto k : konten) { - String konto = k.toString(); - if (konto.contains(name)) { - return true; - } + return konto.auszahlen(betrag, "Auszahlung am Schalter", "Auszahlung", konto.getInhaber()); + } + + public String[] erstelleKontoauszug(int kontonummer) { + Konto konto = bank.findeKonto(kontonummer); + + return konto.getKontobewegungen(); + } + + public boolean überweisungBeauftragen(int startkonto, int zielkonto, long betrag, String verwendungszweck) { + Konto start = bank.findeKonto(startkonto); + Konto ziel = bank.findeKonto(zielkonto); + + if (start instanceof Girokonto && ziel instanceof Girokonto) { + return ((Girokonto)start).Überweise((Girokonto)ziel, betrag, verwendungszweck); } + return false; } - public boolean checkForInstance(int nummer) { - Collection konten = bank.getKontenliste(); - String num = Integer.toString(nummer); - for (Konto k:konten) { - String konto = k.toString(); - if(konto.contains(num)) { - return true; - } - } - return false; - } - public boolean checkForBalance(String inhaber) { - Collection konten = bank.getKontenliste(); - for (Konto k : konten) { - String konto = k.toString(); - if (konto.contains(inhaber)) { - if (k.getKontostand() <= 0) { - return false; - } - } - } - return true; + public long getKontostand(int kontonummer) { + Konto konto = bank.findeKonto(kontonummer); -} - public boolean checkForBalance(int nummer) { - Collection konten = bank.getKontenliste(); - String num = Integer.toString(nummer); - for (Konto k : konten) { - String konto = k.toString(); - if (konto.contains(num)) { - if (k.getKontostand() <= 0) { - return false; - } - } - } - return true; - - } - - public List getAuszüge(int kontonummer) { - return bank.getAuszüge(kontonummer); + return konto.getKontostand(); } } diff --git a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java new file mode 100644 index 0000000..728d84b --- /dev/null +++ b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java @@ -0,0 +1,22 @@ +package de.hs_mannheim.informatik.bank.facade; + +import static org.junit.jupiter.api.Assertions.*; + +import org.junit.jupiter.api.Test; + +class BanksystemTest { + + @Test + void test() { + fail("Not yet implemented"); + } + @Test + void smokeTest() throws Exception { + Banksystem bs = new Banksystem("Testsystem"); + + assertNotNull(bs); + assertEquals(0, bs.getKontenliste().length); + assertEquals("Testsystem", bs.getBankname()); + } + +} diff --git a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/ui/UI.java b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/ui/UI.java index 214afae..cba3429 100644 --- a/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/ui/UI.java +++ b/Bank-BeispielMeins/src/de/hs_mannheim/informatik/bank/ui/UI.java @@ -1,154 +1,67 @@ package de.hs_mannheim.informatik.bank.ui; -import java.util.List; import java.util.Scanner; -import de.hs_mannheim.informatik.bank.domain.Kontobewegungen; import de.hs_mannheim.informatik.bank.facade.Banksystem; public class UI { private Banksystem bs; Scanner sc = new Scanner(System.in); - public UI(Banksystem bs) throws Exception { + public UI(Banksystem bs) { this.bs = bs; hauptmenü(); } - private void hauptmenü() throws Exception { + private void hauptmenü() { System.out.println("Willkommen bei der " + bs.getBankname() + "!"); - mainloop: while (true) { - System.out.println(); - System.out.println("--------"); - System.out.println("Hauptmenü"); - System.out.println("1 -> Konten anzeigen"); - System.out.println("2 -> Konto anlegen"); -// System.out.println("3 -> Auf bestehendes Konto einzahlen oder auszahlen"); - System.out.println("3 -> Auf bestehendes Konto einzahlen/auszahlen"); - System.out.println("4 -> Kontoauszüge"); - System.out.println("9 -> Beenden"); - System.out.println(); - System.out.print("> "); - int input = Integer.parseInt(sc.nextLine()); - System.out.println(); + mainloop: + while (true) { + System.out.println(); + System.out.println("--------"); + System.out.println("Hauptmenü"); + System.out.println("1 -> Konten anzeigen"); + System.out.println("2 -> Konto anlegen"); + System.out.println("3 -> Geld einzahlen"); + System.out.println("4 -> Geld auszahlen"); + System.out.println("5 -> Kontoauszug drucken"); + System.out.println("6 -> Ãœberweisung beauftragen"); - switch (input) { - case 1: - kontenAnzeigen(); - break; - case 2: - kontoAnlegen(); - break; - case 4: - kontoAuszugAnzeigen(); - break; - case 3: - kontoBewegungen(); - break; - case 9: - break mainloop; + System.out.println("9 -> Beenden"); + System.out.println(); + + System.out.print("> "); + int input = Integer.parseInt(sc.nextLine()); + System.out.println(); + + try { + switch(input) { + case 1: kontenAnzeigen(); break; + case 2: + kontoAnlegen(); + break; + case 3: geldEinzahlen(); break; + case 4: geldAuszahlen(); break; + case 5: kontoauszugDrucken(); break; + case 6: überweisungBeauftragen(); break; + case 9: break mainloop; + } + + } catch (Exception e) { + System.err.println(e.getLocalizedMessage()); + } + System.out.println(); } - } + System.out.println("Auf Wiedersehen!"); - } // hauptmenü - private void kontoBewegungen() throws Exception { - System.out.println("1 -> Konto über Namen auswählen"); - System.out.println("2 -> Konto über Nummer auswählen"); - System.out.println(); - System.out.print(">"); - int input = Integer.parseInt(sc.nextLine()); - switch (input) { - case 1: - kÜberNamen(); - break; - case 2: - kÜberNummer(); - break; - } + } // hauptmenü - } - private void kÜberNamen() throws Exception { - System.out.println("Welches Konto? - Namen"); - String name = sc.nextLine(); - if (bs.checkForInstance(name) == true) { - System.out.println("Sie haben das Konto von " + name + " ausgesucht."); - System.out.println("Einzahlen -> 1"); - System.out.println("Auszahlen -> 2"); - System.out.print("> "); - int input = Integer.parseInt(sc.nextLine()); - System.out.println(); - switch (input) { - case 1: - bs.kontoAufladen(name, kontoEinzahlen()); - break; - case 2: - if(bs.checkForBalance(name)== false) { - System.out.println("Sie haben kein Guthaben. Sie müssen erst einzahlen"); - kontoBewegungen();break; - } - bs.kontoAufladen(name, kontoAuszahlen()); - break; - } - } else { - System.out.println("Konto existiert nicht"); - hauptmenü(); - } - } - public void kÜberNummer() throws Exception { - System.out.println("Welches Konto - Nummer"); - int nummer = Integer.parseInt(sc.nextLine()); - if (bs.checkForInstance(nummer) == true) { - System.out.println("Sie haben das Konto " + nummer + " ausgewählt"); - System.out.println("Einzahlen -> 1"); - System.out.println("Auszahlen -> 2"); - System.out.print("> "); - int input = Integer.parseInt(sc.nextLine()); - System.out.println(); - switch (input) { - case 1: - bs.kontoAufladen(nummer, kontoEinzahlen()); - break; - case 2: - if(bs.checkForBalance(nummer)== false) { - System.out.println("Sie haben kein Guthaben. Sie müssen erst einzahlen"); - kontoBewegungen();break; - } - bs.kontoAufladen(nummer, kontoAuszahlen()); - break; - } - } else { - System.out.println("Konto existiert nicht"); - hauptmenü(); - } - } - private long kontoAuszahlen() { - System.out.println("Wieviel möchten sie auszahlen?"); - System.out.print("> "); - long input = Long.parseLong(sc.nextLine()); - System.out.println(); - if (input < 0) { - System.out.println("Sie können nichts unter 0 auszahlen"); - kontoAuszahlen(); - } - return -input; - } - private long kontoEinzahlen() { - System.out.println("Wieviel möchten sie einzahlen?"); - System.out.print("> "); - long input = Long.parseLong(sc.nextLine()); - System.out.println(); - if (input <= 0) { - System.out.println("Sie können nichts unter 0 einzahlen"); - kontoEinzahlen(); - } - return input; - } - private void kontenAnzeigen() { + private void kontenAnzeigen() { String[] konten = bs.getKontenliste(); if (konten.length > 0) { - System.out.println("Folgende Konten sind aktuell verfügbar:"); + System.out.println("Folgende Konten sind aktuell verfügbar:"); for (String s : konten) { System.out.println(s); } @@ -161,135 +74,76 @@ public class UI { System.out.println("Bitte den Namen des Kontoinhabers angeben: "); String name = sc.nextLine(); - int kontonummer = bs.kontoAnlegen(name); + 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, auswahl); System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt."); } - public void kontoAuszugAnzeigen() { - System.out.print("Kontonummer: "); - System.out.println(); + + private void geldEinzahlen() throws Exception { + System.out.println("Geld einzahlen"); + System.out.print("Bitte die gewünschte Kontonummer eingeben: "); int kontonummer = Integer.parseInt(sc.nextLine()); - if (!bs.checkForInstance(kontonummer)) { - System.out.println("Kein Konto vorhanden"); - return; - } - List auszüge = bs.getAuszüge(kontonummer); - - for(Kontobewegungen auszug : auszüge) { - System.out.println(auszug); - } + + // optional prüfen, ob Konto existiert + + System.out.print("Bitte den gewünschten Betrag eingeben: "); + double betrag = Double.parseDouble(sc.nextLine()); + + long neuerKontostand = bs.geldEinzahlen(kontonummer, (long)betrag * 100); + + System.out.printf("Einzahlung erfolgreich, neuer Kontostand = %.2f Euro", (neuerKontostand / 100.0)); } -// private void kontoAktionen() { -// System.out.println("Konto über Namen auffüllen? -> 1"); -// System.out.println("Konto über Kontonummer aufladen? -> 2"); -// System.out.println("Konto über Namen auszahlen -> 3"); -// System.out.println("Konto über Nummer auszahlen -> 4"); -// System.out.println(); -// System.out.print(">"); -// int input = Integer.parseInt(sc.nextLine()); -// switch (input) { -// case 1: -// kÜberNamenEinzahlen(); -// break; -// case 2: -// kÜberNummerEinzahlen(); -// break; -// case 3: -// kÜberNamenAuszahlen(); -// break; -// case 4: -// KÜberNummerAuszahlen(); -// break; -// } -// -//} -//private void KÜberNummerAuszahlen() { -// System.out.println("Welches Konto soll auszahlen? Nummer"); -// CharSequence input = sc.nextLine(); -// String[] konten = bs.getKontenliste(); -// long input2 = 0; -// for (String k : konten) { -// if (k.contains(input)) { -// System.out.print("Aktueller Stand: "); -// if (bs.checkForBalance(k) == false) { -// System.out.println("Sie müssen erst einzahlen um auszahlen zu können"); -// kontoAktionen(); -// break; -// } -// System.out.println("Wieviel möchten sie auszahlen?"); -// input2 = Long.parseLong(sc.nextLine()); -// input2 = input2 * -1; -// bs.kontoAufladen(k, input2); -// System.out.println(k.toString()); -// } -// } -// -//} + private void geldAuszahlen() throws Exception { + System.out.println("Geld auszahlen"); + System.out.print("Bitte die gewünschte Kontonummer eingeben: "); + int kontonummer = Integer.parseInt(sc.nextLine()); -//private void kÜberNamenAuszahlen() { -// System.out.println("Welches Konto soll auszahlen? Namen"); -// String input = sc.nextLine(); -// String[] konten = bs.getKontenliste(); -// long input2 = 0; -// for (String k : konten) { -// if (k.contains(input)) { -// System.out.print("Aktueller Stand: "); -// if (bs.checkForBalance(k) == false) { -// System.out.println("Sie müssen erst einzahlen um auszahlen zu können"); -// kontoAktionen(); -// break; -// } -// System.out.println("Wieviel möchten sie auszahlen?"); -// input2 = Long.parseLong(sc.nextLine()); -// input2 = input2 * -1; -// bs.kontoAufladen(k, input2); -// System.out.println(k.toString()); -// } -// } -//} + System.out.print("Bitte den gewünschten Betrag eingeben: "); + double betrag = Double.parseDouble(sc.nextLine()); -//private void kÜberNamenEinzahlen() { -// System.out.println("Welches Konto soll aufgeladen werden? Name"); -// String input = sc.nextLine(); -// -// String[] konten = bs.getKontenliste(); -// for (String k : konten) { -// -// if (k.contains(input)) { -// System.out.print("auf dieses Konto wird geladen: "); -// System.out.println(k.toString()); -// System.out.println("Wieviel möchten sie aufladen?"); -// System.out.print(">"); -// long input2 = Long.parseLong(sc.nextLine()); -// if (input2 < 0) { -// System.out.println("Betrag muss plus sein"); -// kÜberNamenEinzahlen(); -// } -// bs.kontoAufladen(k, input2); -// } -// System.out.println(k.toString()); -// } -//} + boolean erfolgreich = bs.geldAuszahlen(kontonummer, (long)betrag * 100); -//private void kÜberNummerEinzahlen() { -// System.out.println("Welches Konto soll aufgeladen werden? Nummer"); -// CharSequence input = sc.nextLine(); -// String[] konten = bs.getKontenliste(); -// for (String k : konten) { -// if (k.contains(input)) { -// System.out.print("auf dieses Konto wird geladen: "); -// System.out.println(k.toString()); -// System.out.println("Wieviel möchten sie aufladen?"); -// System.out.print(">"); -// long input2 = Long.parseLong(sc.nextLine()); -// if (input2 < 0) { -// System.out.println("Betrag muss plus sein"); -// kÜberNummerEinzahlen(); -// } -// bs.kontoAufladen(k, input2); -// } -// } -//} + System.out.printf("Auszahlung" + ((!erfolgreich)? " nicht" : "" )+ " erfolgreich. "); + System.out.printf("Neuer Kontostand = %.2f Euro.", (bs.getKontostand(kontonummer) / 100.0)); + } + private void kontoauszugDrucken() { + System.out.print("Bitte die gewünschte Kontonummer für den Auszug eingeben: "); + int kontonummer = Integer.parseInt(sc.nextLine()); + + System.out.println(); + + // in echt auf einem Drucker + System.out.println("Auszug für Konto " + kontonummer); + String[] kontobewegungen = bs.erstelleKontoauszug(kontonummer); + + if (kontobewegungen.length > 0) + for (String kb : kontobewegungen) { + System.out.println(kb); + } + else + System.out.println("Noch keine Kontobewegungen."); + } + + private void überweisungBeauftragen() { + 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: "); + double betrag = Double.parseDouble(sc.nextLine()); + + System.out.print("Bitte den Verwendungszweck eingeben: "); + String verwendungszweck = sc.nextLine(); + + boolean erfolgreich = bs.überweisungBeauftragen(startkonto, zielkonto, (long)(betrag * 100), verwendungszweck); + + System.out.println("Ãœberweisung" + ( (!erfolgreich) ? " nicht" : "") + " erfolgreich ausgeführt."); + } }