forked from hummel/Bank-System
Girokonto und kontoauszug mit einer Kontobewegung hinzugefügt!
parent
be3311eddd
commit
0b82367733
|
@ -1,26 +1,38 @@
|
||||||
package de.hs_mannheim.informatik.bank.domain;
|
package de.hs_mannheim.informatik.bank.domain;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.FileNotFoundException;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.ObjectInputStream;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
|
|
||||||
public class Bank {
|
public class Bank {
|
||||||
private String name;
|
private String name;
|
||||||
private HashMap<Integer, Konto> konten = new HashMap<>();
|
private HashMap<Integer, Konto> konten = new HashMap<>();
|
||||||
|
|
||||||
public Bank(String name) {
|
public Bank(String name) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addKonto(Konto k) {
|
public void addKonto(Konto k) {
|
||||||
konten.put(k.getKontonummer(), k);
|
konten.put(k.getKontonummer(), k);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Konto findeKontoNummer(int kontonummer) {
|
||||||
|
return konten.get(kontonummer);
|
||||||
|
}
|
||||||
public Collection<Konto> getKontenliste() {
|
public Collection<Konto> getKontenliste() {
|
||||||
return konten.values();
|
return konten.values();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,10 @@
|
||||||
|
package de.hs_mannheim.informatik.bank.domain;
|
||||||
|
|
||||||
|
public class GiroKonto extends Konto{
|
||||||
|
|
||||||
|
public GiroKonto(String inhaber, long kontoStand) {
|
||||||
|
super(inhaber, kontoStand);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -1,5 +1,8 @@
|
||||||
package de.hs_mannheim.informatik.bank.domain;
|
package de.hs_mannheim.informatik.bank.domain;
|
||||||
|
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
public class Konto {
|
public class Konto {
|
||||||
private static int kontozähler = 0;
|
private static int kontozähler = 0;
|
||||||
|
|
||||||
|
@ -7,11 +10,16 @@ public class Konto {
|
||||||
// private long stand = 0;
|
// private long stand = 0;
|
||||||
private String inhaber;
|
private String inhaber;
|
||||||
private long kontoStand;
|
private long kontoStand;
|
||||||
|
private ArrayList<String> liste = new ArrayList<>();
|
||||||
|
private ArrayList<KontoBewegung> bewegungen = new ArrayList<>();
|
||||||
|
|
||||||
|
|
||||||
public Konto(String inhaber, long kontoStand) {
|
public Konto(String inhaber, long kontoStand) {
|
||||||
nummer = 1000 + kontozähler++;
|
nummer = 1000 + kontozähler++;
|
||||||
this.inhaber = inhaber;
|
this.inhaber = inhaber;
|
||||||
this.kontoStand = kontoStand;
|
this.kontoStand = kontoStand;
|
||||||
|
|
||||||
|
this.bewegungen = new ArrayList<>();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -36,11 +44,17 @@ public class Konto {
|
||||||
System.out.println("Einzahlung kann nicht getätigt werden, da es eine negativ Zahl ist! ");
|
System.out.println("Einzahlung kann nicht getätigt werden, da es eine negativ Zahl ist! ");
|
||||||
} else {
|
} else {
|
||||||
kontoStand += betrag;
|
kontoStand += betrag;
|
||||||
System.out.println("Der Betrag wurde eingezahlt! ");
|
System.out.println("Der Betrag wurde eingezahlt!");
|
||||||
|
|
||||||
|
liste.add("Datum " + LocalDateTime.now() + " neuer KontoStand " + kontoStand + "\n");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// bewegungen.add (new KontoBewegung(betrag,"Einzahlung am Schalter","Einzaglung",inhaber));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void geldAuszahlen(double betrag) {
|
public void geldAuszahlen(double betrag) {
|
||||||
if (betrag <= 0 || betrag > kontoStand) {
|
if (betrag <= 0 || betrag > kontoStand) {
|
||||||
System.out.println(
|
System.out.println(
|
||||||
|
@ -54,6 +68,16 @@ public class Konto {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ArrayList<String> getListe() {
|
||||||
|
return liste;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void KontoAuszug() {
|
||||||
|
for (int i = 0; i < liste.size(); i++) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "Konto [nummer= " + nummer + ", inhaber= " + inhaber + ", kontoStand= " + kontoStand + "€" + " ]";
|
return "Konto [nummer= " + nummer + ", inhaber= " + inhaber + ", kontoStand= " + kontoStand + "€" + " ]";
|
||||||
|
|
|
@ -1,5 +1,30 @@
|
||||||
package de.hs_mannheim.informatik.bank.domain;
|
package de.hs_mannheim.informatik.bank.domain;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
public class KontoBewegung {
|
public class KontoBewegung {
|
||||||
|
|
||||||
|
private long betrag;
|
||||||
|
private Date date;
|
||||||
|
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.date = new Date();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "KontoBewegung [betrag=" + betrag + ", date=" + date + ", betreff=" + betreff + ", art=" + art
|
||||||
|
+ ", auftragGeber=" + auftragGeber + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,22 +1,49 @@
|
||||||
package de.hs_mannheim.informatik.bank.facade;
|
package de.hs_mannheim.informatik.bank.facade;
|
||||||
|
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.FileNotFoundException;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.ObjectInputStream;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
|
||||||
import de.hs_mannheim.informatik.bank.domain.Bank;
|
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.Konto;
|
||||||
|
|
||||||
public class Banksystem {
|
public class Banksystem {
|
||||||
private Bank bank;
|
private Bank bank;
|
||||||
|
|
||||||
|
// private HashMap<Integer,Konto>konten = new HashMap<>();
|
||||||
|
// private Collection<Konto>konten = bank.getKontenliste();
|
||||||
|
|
||||||
public Banksystem(String bankname) {
|
public Banksystem(String bankname) {
|
||||||
this.bank = new Bank(bankname);
|
this.bank = new Bank(bankname);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void datenspeichern() throws FileNotFoundException, IOException, ClassNotFoundException {
|
||||||
|
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("src/Kundenliste.ser"));
|
||||||
|
// konten = (HashMap<Integer,Konto>)ois.readObject();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public int kontoAnlegen(String name, long kontoStand) {
|
public int kontoAnlegen(String name, long kontoStand) {
|
||||||
Konto k = new Konto(name, kontoStand);
|
Konto k = new Konto(name, kontoStand);
|
||||||
bank.addKonto(k);
|
bank.addKonto(k);
|
||||||
|
|
||||||
return k.getKontonummer();
|
return k.getKontonummer();
|
||||||
|
|
||||||
|
|
||||||
|
// Konto k = new Konto(name, kontoStand);
|
||||||
|
// if (auswahl == 1) {
|
||||||
|
//
|
||||||
|
// } else {
|
||||||
|
// k = new GiroKonto(name, 0);
|
||||||
|
//
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// bank.addKonto(k);
|
||||||
|
//
|
||||||
|
// return k.getKontonummer();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -40,21 +67,6 @@ public class Banksystem {
|
||||||
return liste;
|
return liste;
|
||||||
}
|
}
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Einzelnes Konto kann per Kontonummer abgefragt werden!
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// public void kontoInformationen(int kontonummer) {
|
|
||||||
// Collection<Konto> konten = bank.getKontenliste();
|
|
||||||
// for (Konto k : konten) {
|
|
||||||
// if (k.getKontonummer() == kontonummer) {
|
|
||||||
// k.getkontoStand();
|
|
||||||
// }else {
|
|
||||||
// System.out.println("Konro nicht vorhanden!");
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
|
|
||||||
public boolean kontoVorhanden(int kontonummer) {
|
public boolean kontoVorhanden(int kontonummer) {
|
||||||
Collection<Konto> konten = bank.getKontenliste();
|
Collection<Konto> konten = bank.getKontenliste();
|
||||||
for (Konto k : konten) {
|
for (Konto k : konten) {
|
||||||
|
@ -67,6 +79,36 @@ public class Banksystem {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void KontoAuszug(int kontonummer) {
|
||||||
|
Collection<Konto> konten = bank.getKontenliste();
|
||||||
|
for (Konto k : konten) {
|
||||||
|
if (k.getKontonummer() == kontonummer) {
|
||||||
|
k.getKontonummer();
|
||||||
|
System.out.println(k.getListe());
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* KontoInformationen!
|
||||||
|
*/
|
||||||
|
|
||||||
|
public void kontoInformationen(int kontonummer) {
|
||||||
|
Collection<Konto> konten = bank.getKontenliste();
|
||||||
|
for (Konto k : konten) {
|
||||||
|
if (k.getKontonummer() == kontonummer) {
|
||||||
|
k.getKontonummer();
|
||||||
|
k.getkontoInhaber();
|
||||||
|
System.out.println("Der Kontoinhaber " + k.getkontoInhaber() + " mit der folgenden Kontonummer "
|
||||||
|
+ k.getKontonummer());
|
||||||
|
|
||||||
|
} else {
|
||||||
|
System.out.println("Konto nicht vorhanden! ");
|
||||||
|
// throw new RuntimeException("Konto nicht vorhanden!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Der Kontostand wird abgefragt.
|
* Der Kontostand wird abgefragt.
|
||||||
*/
|
*/
|
||||||
|
@ -104,11 +146,10 @@ public class Banksystem {
|
||||||
Collection<Konto> konten = bank.getKontenliste();
|
Collection<Konto> konten = bank.getKontenliste();
|
||||||
for (Konto k : konten) {
|
for (Konto k : konten) {
|
||||||
if (k.getKontonummer() == kontonummer) {
|
if (k.getKontonummer() == kontonummer) {
|
||||||
k.geldAuszahlen(betrag);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (k.getKontonummer() != kontonummer) {
|
if (k.getKontonummer() != kontonummer) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (k.getkontoStand() >= betrag) {
|
if (k.getkontoStand() >= betrag) {
|
||||||
|
@ -124,4 +165,3 @@ public class Banksystem {
|
||||||
return bank.getName();
|
return bank.getName();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,15 +23,16 @@ 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 -> Kontostand abfragen");
|
System.out.println("3 -> Kontostand abfragen");
|
||||||
System.out.println("4 -> Geld einzahlen");
|
System.out.println("4 -> KontoInformation");
|
||||||
System.out.println("5 -> Geld abheben");
|
System.out.println("5 -> KontoAuszug");
|
||||||
|
System.out.println("6 -> Geld einzahlen");
|
||||||
|
System.out.println("7 -> Geld abheben");
|
||||||
System.out.println("9 -> Beenden");
|
System.out.println("9 -> Beenden");
|
||||||
System.out.println();
|
System.out.println();
|
||||||
|
|
||||||
System.out.print("> ");
|
System.out.print("> ");
|
||||||
|
|
||||||
int input = Integer.parseInt(sc.nextLine());
|
int input = Integer.parseInt(sc.nextLine());
|
||||||
// int input = sc.nextInt();
|
|
||||||
|
|
||||||
System.out.println();
|
System.out.println();
|
||||||
|
|
||||||
|
@ -46,9 +47,15 @@ public class UI {
|
||||||
kontenStandAbfragen();
|
kontenStandAbfragen();
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
geldEinzahlen();
|
kontoInformationen();
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
|
KontoAuszug();
|
||||||
|
break;
|
||||||
|
case 6:
|
||||||
|
geldEinzahlen();
|
||||||
|
break;
|
||||||
|
case 7:
|
||||||
geldAuszahlen();
|
geldAuszahlen();
|
||||||
break;
|
break;
|
||||||
case 9:
|
case 9:
|
||||||
|
@ -61,6 +68,20 @@ public class UI {
|
||||||
sc.close();
|
sc.close();
|
||||||
} // hauptmenü
|
} // hauptmenü
|
||||||
|
|
||||||
|
private void KontoAuszug() {
|
||||||
|
System.out.println("Bitte geben Sie ihre Kontonummer ein ");
|
||||||
|
int kNr = Integer.parseInt(sc.nextLine());
|
||||||
|
bs.KontoAuszug(kNr);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void kontoInformationen() {
|
||||||
|
System.out.println("Bitte geben Sie ihre Kontonummer ein ");
|
||||||
|
int kNr = Integer.parseInt(sc.nextLine());
|
||||||
|
bs.kontoInformationen(kNr);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
private void kontenAnzeigen() {
|
private void kontenAnzeigen() {
|
||||||
String[] konten = bs.getKontenliste();
|
String[] konten = bs.getKontenliste();
|
||||||
if (konten.length > 0) {
|
if (konten.length > 0) {
|
||||||
|
@ -76,6 +97,10 @@ public class UI {
|
||||||
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();
|
||||||
|
|
||||||
|
System.out.println("Möchetn Sie ein Sparkonto(1) oder ein Girokonto(2) anlegen");
|
||||||
|
int auswahl= Integer.parseInt(sc.nextLine());
|
||||||
|
|
||||||
int kontonummer = bs.kontoAnlegen(name, 0);
|
int kontonummer = bs.kontoAnlegen(name, 0);
|
||||||
System.out.println("Konto mit der Nummer " + kontonummer);
|
System.out.println("Konto mit der Nummer " + kontonummer);
|
||||||
|
|
||||||
|
@ -121,7 +146,7 @@ public class UI {
|
||||||
double betrag = Double.parseDouble(sc.nextLine());
|
double betrag = Double.parseDouble(sc.nextLine());
|
||||||
|
|
||||||
bs.abheben(betrag, kNr);
|
bs.abheben(betrag, kNr);
|
||||||
}else {
|
} else {
|
||||||
System.out.println("Konto nicht vorhanden!");
|
System.out.println("Konto nicht vorhanden!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue