New: Depot Klasse erstellt und UI dafür verbessert
parent
25f5622463
commit
2d4bee61bf
|
@ -12,11 +12,16 @@ public class Bank implements Serializable {
|
||||||
private HashMap<Integer, Kunde> kundenMap = new HashMap<>();
|
private HashMap<Integer, Kunde> kundenMap = new HashMap<>();
|
||||||
private int kontozähler;
|
private int kontozähler;
|
||||||
private int kundenzähler;
|
private int kundenzähler;
|
||||||
|
private String aktienName;
|
||||||
|
private int aktienPreis;
|
||||||
|
|
||||||
|
|
||||||
public Bank(String name) {
|
public Bank(String name) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
this.kontozähler = -1;
|
this.kontozähler = -1;
|
||||||
this.kundenzähler = -1;
|
this.kundenzähler = -1;
|
||||||
|
this.aktienName = "BMW";
|
||||||
|
this.aktienPreis = 20;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int addKonto(Kunde kundenMap, int auswahl) {
|
public int addKonto(Kunde kundenMap, int auswahl) {
|
||||||
|
@ -24,8 +29,11 @@ public class Bank implements Serializable {
|
||||||
|
|
||||||
if (auswahl == 1)
|
if (auswahl == 1)
|
||||||
k = new Konto(kundenMap, ++kontozähler);
|
k = new Konto(kundenMap, ++kontozähler);
|
||||||
else
|
else if (auswahl == 2)
|
||||||
k = new Girokonto(kundenMap, ++kontozähler);
|
k = new Girokonto(kundenMap, ++kontozähler);
|
||||||
|
else {
|
||||||
|
k = new Depot(kundenMap, ++kontozähler);
|
||||||
|
}
|
||||||
|
|
||||||
konten.put(k.getKontonummer(), k);
|
konten.put(k.getKontonummer(), k);
|
||||||
kundenMap.addKonto(k);
|
kundenMap.addKonto(k);
|
||||||
|
@ -88,5 +96,12 @@ public class Bank implements Serializable {
|
||||||
return k.getKonten();
|
return k.getKonten();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getAktienName() {
|
||||||
|
return this.aktienName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getAktienPreis() {
|
||||||
|
return aktienPreis;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,50 @@
|
||||||
|
package de.hs_mannheim.informatik.bank.domain;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileNotFoundException;
|
||||||
|
import java.util.Scanner;
|
||||||
|
|
||||||
|
public class Depot extends Konto{
|
||||||
|
|
||||||
|
|
||||||
|
public Depot(Kunde kunde, int kontozähler) {
|
||||||
|
super(kunde, kontozähler);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "Depot mit der Kontonummer " + super.getKontonummer() + " angelegt.";
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean aktienKaufen(int anzahl){
|
||||||
|
|
||||||
|
if (super.getKontostand() >= anzahl * 20){
|
||||||
|
long betrag = anzahl * 20;
|
||||||
|
super.auszahlen(betrag, "Aktien", "Aktienkauf", "super.getKunde().getName()");
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void fileReader(String filename){
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
Scanner scanner = new Scanner(new File(filename));
|
||||||
|
while(scanner.hasNext()){
|
||||||
|
System.out.println(scanner.nextLine());
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (FileNotFoundException e) {
|
||||||
|
System.err.println("Datei nicht gefunden");
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -1,9 +1,8 @@
|
||||||
package de.hs_mannheim.informatik.bank.domain;
|
package de.hs_mannheim.informatik.bank.domain;
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
|
|
||||||
public class Girokonto extends Konto{
|
public class Girokonto extends Konto{
|
||||||
private static final long serialVersionUID = 1L;
|
|
||||||
private long dispo = 100000;
|
private long dispo = 100000;
|
||||||
|
|
||||||
public Girokonto(Kunde kunde, int kontozähler) {
|
public Girokonto(Kunde kunde, int kontozähler) {
|
||||||
|
|
|
@ -5,6 +5,7 @@ import java.util.Collection;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
import de.hs_mannheim.informatik.bank.domain.Bank;
|
import de.hs_mannheim.informatik.bank.domain.Bank;
|
||||||
|
import de.hs_mannheim.informatik.bank.domain.Depot;
|
||||||
import de.hs_mannheim.informatik.bank.domain.Girokonto;
|
import de.hs_mannheim.informatik.bank.domain.Girokonto;
|
||||||
import de.hs_mannheim.informatik.bank.domain.Konto;
|
import de.hs_mannheim.informatik.bank.domain.Konto;
|
||||||
import de.hs_mannheim.informatik.bank.domain.Kunde;
|
import de.hs_mannheim.informatik.bank.domain.Kunde;
|
||||||
|
@ -13,6 +14,7 @@ import de.hs_mannheim.informatik.bank.infrastructure.Persistenz;
|
||||||
public class Banksystem {
|
public class Banksystem {
|
||||||
private Bank bank;
|
private Bank bank;
|
||||||
private Kunde currentKunde;
|
private Kunde currentKunde;
|
||||||
|
|
||||||
|
|
||||||
public Banksystem(String bankname) {
|
public Banksystem(String bankname) {
|
||||||
if (Persistenz.sindDatenGespeichert(bankname))
|
if (Persistenz.sindDatenGespeichert(bankname))
|
||||||
|
@ -37,17 +39,6 @@ public class Banksystem {
|
||||||
return kontonummer;
|
return kontonummer;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String[] getKontenliste() {
|
|
||||||
Collection<Konto> konten = bank.getKontenliste();
|
|
||||||
String[] liste = new String[konten.size()];
|
|
||||||
|
|
||||||
int i = 0;
|
|
||||||
for (Konto k : konten) {
|
|
||||||
liste[i++] = k.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
return liste;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getBankname() {
|
public String getBankname() {
|
||||||
return bank.getName();
|
return bank.getName();
|
||||||
|
@ -126,6 +117,24 @@ public class Banksystem {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean aktienKaufen(int kontonummer, int anzahl){
|
||||||
|
|
||||||
|
Konto konto = bank.findeKonto(kontonummer);
|
||||||
|
|
||||||
|
if (konto instanceof Depot){
|
||||||
|
|
||||||
|
boolean erfolg = ((Depot) konto).aktienKaufen(anzahl);
|
||||||
|
|
||||||
|
|
||||||
|
return erfolg;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public long getKontostand(int kontonummer) {
|
public long getKontostand(int kontonummer) {
|
||||||
Konto konto = bank.findeKonto(kontonummer);
|
Konto konto = bank.findeKonto(kontonummer);
|
||||||
|
|
||||||
|
@ -174,4 +183,12 @@ public class Banksystem {
|
||||||
return bank.getKundenzähler();
|
return bank.getKundenzähler();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getAktienName(){
|
||||||
|
return bank.getAktienName();
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getAktienPreis(){
|
||||||
|
return bank.getAktienPreis();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,65 +1,65 @@
|
||||||
package de.hs_mannheim.informatik.bank.gui;
|
// package de.hs_mannheim.informatik.bank.gui;
|
||||||
|
|
||||||
//import java.awt.Container;
|
// //import java.awt.Container;
|
||||||
import java.awt.event.ActionEvent;
|
// import java.awt.event.ActionEvent;
|
||||||
import java.awt.event.ActionListener;
|
// import java.awt.event.ActionListener;
|
||||||
|
|
||||||
|
|
||||||
import javax.swing.JButton;
|
// import javax.swing.JButton;
|
||||||
import javax.swing.JFrame;
|
// import javax.swing.JFrame;
|
||||||
import javax.swing.JScrollPane;
|
// import javax.swing.JScrollPane;
|
||||||
import javax.swing.JTextArea;
|
// import javax.swing.JTextArea;
|
||||||
import javax.swing.JTextField;
|
// import javax.swing.JTextField;
|
||||||
|
|
||||||
import de.hs_mannheim.informatik.bank.facade.Banksystem;
|
// import de.hs_mannheim.informatik.bank.facade.Banksystem;
|
||||||
|
|
||||||
public class KontoListingFrame extends JFrame implements ActionListener {
|
// public class KontoListingFrame extends JFrame implements ActionListener {
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
// private static final long serialVersionUID = 1L;
|
||||||
private JTextField eingabe;
|
// private JTextField eingabe;
|
||||||
private JTextArea ausgabe;
|
// private JTextArea ausgabe;
|
||||||
private JButton ok;
|
// private JButton ok;
|
||||||
|
|
||||||
private Banksystem bs;
|
// private Banksystem bs;
|
||||||
|
|
||||||
public KontoListingFrame(Banksystem bs) {
|
// public KontoListingFrame(Banksystem bs) {
|
||||||
this.bs = bs;
|
// this.bs = bs;
|
||||||
|
|
||||||
this.setTitle(bs.getBankname());
|
// this.setTitle(bs.getBankname());
|
||||||
this.setSize(300, 300);
|
// this.setSize(300, 300);
|
||||||
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
|
// this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
|
||||||
|
|
||||||
eingabe = new JTextField(20);
|
// eingabe = new JTextField(20);
|
||||||
|
|
||||||
ausgabe = new JTextArea(5, 20);
|
// ausgabe = new JTextArea(5, 20);
|
||||||
ausgabe.setLineWrap(true);
|
// ausgabe.setLineWrap(true);
|
||||||
ausgabe.setWrapStyleWord(true);
|
// ausgabe.setWrapStyleWord(true);
|
||||||
|
|
||||||
// Die Ausgabe automatisch scrollbar machen, wenn Sie nicht
|
// // Die Ausgabe automatisch scrollbar machen, wenn Sie nicht
|
||||||
// mehr auf den Bildschirm passen sollte.
|
// // mehr auf den Bildschirm passen sollte.
|
||||||
JScrollPane sp = new JScrollPane(ausgabe);
|
// JScrollPane sp = new JScrollPane(ausgabe);
|
||||||
|
|
||||||
ok = new JButton("Kontenliste abrufen");
|
// ok = new JButton("Kontenliste abrufen");
|
||||||
ok.addActionListener(this);
|
// ok.addActionListener(this);
|
||||||
|
|
||||||
//Container cp = this.getContentPane();
|
// //Container cp = this.getContentPane();
|
||||||
this.add(eingabe, "North");
|
// this.add(eingabe, "North");
|
||||||
this.add(sp, "Center");
|
// this.add(sp, "Center");
|
||||||
this.add(ok, "South");
|
// this.add(ok, "South");
|
||||||
}
|
// }
|
||||||
|
|
||||||
@Override
|
// @Override
|
||||||
public void actionPerformed(ActionEvent e) {
|
// public void actionPerformed(ActionEvent e) {
|
||||||
System.out.println("Kontenliste abrufen...");
|
// System.out.println("Kontenliste abrufen...");
|
||||||
|
|
||||||
ausgabe.setText("");
|
// ausgabe.setText("");
|
||||||
String[] konten = bs.getKontenliste();
|
// String[] konten = bs.getKontenliste();
|
||||||
|
|
||||||
for (String konto : konten) {
|
// for (String konto : konten) {
|
||||||
ausgabe.append(konto + "\n");
|
// ausgabe.append(konto + "\n");
|
||||||
}
|
// }
|
||||||
|
|
||||||
|
|
||||||
}
|
// }
|
||||||
|
|
||||||
}
|
// }
|
||||||
|
|
|
@ -30,9 +30,9 @@ public class TUI {
|
||||||
System.out.println("6 -> Kontoauszug drucken");
|
System.out.println("6 -> Kontoauszug drucken");
|
||||||
System.out.println("7 -> Überweisung beauftragen");
|
System.out.println("7 -> Überweisung beauftragen");
|
||||||
System.out.println("8 -> Saldo abfragen");
|
System.out.println("8 -> Saldo abfragen");
|
||||||
|
System.out.println("9 -> Aktien kaufen");
|
||||||
|
|
||||||
System.out.println("9 -> Beenden");
|
System.out.println("10 -> Beenden");
|
||||||
System.out.println();
|
System.out.println();
|
||||||
|
|
||||||
System.out.print("> ");
|
System.out.print("> ");
|
||||||
|
@ -68,8 +68,10 @@ public class TUI {
|
||||||
case 8:
|
case 8:
|
||||||
saldoAbfragen();
|
saldoAbfragen();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 9:
|
case 9:
|
||||||
|
aktienKaufen();
|
||||||
|
break;
|
||||||
|
case 10:
|
||||||
break mainloop;
|
break mainloop;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -83,6 +85,21 @@ public class TUI {
|
||||||
|
|
||||||
} // hauptmenü
|
} // hauptmenü
|
||||||
|
|
||||||
|
private void aktienKaufen() {
|
||||||
|
|
||||||
|
System.out.println("Aktuell verfügbare Aktien: " + bs.getAktienName() + ", Preis pro Aktie: " + bs.getAktienPreis());
|
||||||
|
System.out.println("Geben Sie die Anzahl der Aktien ein, die Sie kaufen möchten: ");
|
||||||
|
int anzahl = Integer.parseInt(sc.nextLine());
|
||||||
|
|
||||||
|
System.out.println("Geben Sie Ihre Kontonummer ein: ");
|
||||||
|
int kontonummer = Integer.parseInt(sc.nextLine());
|
||||||
|
|
||||||
|
boolean erfolgreich = bs.aktienKaufen(kontonummer, anzahl);
|
||||||
|
|
||||||
|
System.out.println("Überweisung" + ((!erfolgreich) ? " nicht" : "") + " erfolgreich ausgeführt.");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
private void kontoAnlegen() throws IOException{
|
private void kontoAnlegen() throws IOException{
|
||||||
System.out.println("Bitte geben Sie Ihre Kunden ID ein: ");
|
System.out.println("Bitte geben Sie Ihre Kunden ID ein: ");
|
||||||
System.out.println("> ");
|
System.out.println("> ");
|
||||||
|
@ -91,7 +108,7 @@ public class TUI {
|
||||||
|
|
||||||
if(bs.getCurrentKunde() != null){
|
if(bs.getCurrentKunde() != null){
|
||||||
|
|
||||||
System.out.println("Möchten Sie ein Sparkonto (1) oder ein Girokonto (2) anlegen?");
|
System.out.println("Möchten Sie ein Sparkonto (1), ein Girokonto (2) oder ein Depot (3) anlegen?");
|
||||||
int auswahl = Integer.parseInt(sc.nextLine());
|
int auswahl = Integer.parseInt(sc.nextLine());
|
||||||
int kontonummer = bs.kontoAnlegen(bs.getCurrentKunde(), auswahl);
|
int kontonummer = bs.kontoAnlegen(bs.getCurrentKunde(), auswahl);
|
||||||
System.out.println("Konto mit der Kontonummer " + kontonummer + " neu angelegt.");
|
System.out.println("Konto mit der Kontonummer " + kontonummer + " neu angelegt.");
|
||||||
|
|
Loading…
Reference in New Issue