Compare commits

...

6 Commits
test ... main

Author SHA1 Message Date
WummerMIB fbdb185b21 start gui 2022-11-22 19:38:39 +01:00
WummerMIB 29ac6122ac added own Exceptiom NotEnoughMoneyException 2022-11-09 09:10:38 +01:00
WummerMIB 37067f47d8 changed own Exception 2022-11-09 09:03:11 +01:00
WummerMIB 8d57d6dc8f bug fixed can see all Konten in Kunden 2022-11-09 07:39:00 +01:00
david c2bb86734b last 2022-11-08 14:46:25 +01:00
david 16e7e012df Eigene Exception + Fehler behoben bei kontoAnlegen 2022-11-08 13:27:30 +01:00
12 changed files with 283 additions and 42 deletions

View File

@ -1,13 +1,15 @@
package de.hs_mannheim.informatik.bank; package de.hs_mannheim.informatik.bank;
import de.hs_mannheim.informatik.bank.facade.Banksystem; import de.hs_mannheim.informatik.bank.facade.Banksystem;
import de.hs_mannheim.informatik.bank.gui.GUI;
import de.hs_mannheim.informatik.bank.ui.UI; import de.hs_mannheim.informatik.bank.ui.UI;
public class Main { public class Main {
public static void main(String[] args) throws Exception { public static void main(String[] args) throws Exception {
Banksystem bs = new Banksystem("Spaßkasse Mannheim"); Banksystem bs = new Banksystem("Spaßkasse Mannheim");
UI ui = new UI(bs); //UI ui = new UI(bs);
GUI gui = new GUI(bs);
} }
} }

View File

@ -1,6 +1,7 @@
package de.hs_mannheim.informatik.bank.domain; package de.hs_mannheim.informatik.bank.domain;
import java.io.Serializable; import java.io.Serializable;
import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.HashMap; import java.util.HashMap;
@ -9,8 +10,6 @@ import org.hamcrest.core.IsInstanceOf;
import de.hs_mannheim.informatik.bank.facade.Banksystem; import de.hs_mannheim.informatik.bank.facade.Banksystem;
import de.hs_mannheim.informatik.bank.ui.UI; import de.hs_mannheim.informatik.bank.ui.UI;
public class Bank implements Serializable { public class Bank implements Serializable {
private String name; private String name;
private HashMap<Integer, Konto> konten = new HashMap<>(); private HashMap<Integer, Konto> konten = new HashMap<>();
@ -23,34 +22,41 @@ public class Bank implements Serializable {
this.kontozähler = -1; this.kontozähler = -1;
} }
public void kaufeAktien(int kontonummer, int idAktien) { public void kaufeAktien(int kontonummer, int idAktien) {
Konto kd = konten.get(kontonummer); Konto kd = konten.get(kontonummer);
Aktien ak = wertpapiere.get(idAktien); Aktien ak = wertpapiere.get(idAktien);
System.out.println(ak.toString()); System.out.println(ak.toString());
if(kd instanceof Depot) { if (kd instanceof Depot) {
((Depot)kd).kaufeAktien((Depot)kd, ak); ((Depot) kd).kaufeAktien((Depot) kd, ak);
ak.setInhaber(kd); ak.setInhaber(kd);
System.out.println(ak.toString()); System.out.println(ak.toString());
} }
} }
public int addKonto(String name, int auswahl , int id) { public int addKonto(String name, int auswahl, int id) throws KundeNullException {
Konto k; Konto k;
if (auswahl == 1) { if (auswahl == 1) {
k = new Konto(name, ++kontozähler); k = new Konto(name, ++kontozähler);
Kunde ku = kunden.get(id); Kunde ku = kunden.get(id);
k.setKunde(ku);} if (ku == null) {
else if(auswahl == 2) { throw new KundeNullException();
}
k.setKunde(ku.getId());
} else if (auswahl == 2) {
k = new Girokonto(name, ++kontozähler); k = new Girokonto(name, ++kontozähler);
Kunde ku = kunden.get(id); Kunde ku = kunden.get(id);
k.setKunde(ku); if (ku == null) {
throw new KundeNullException();
}
k.setKunde(ku.getId());
} else { } else {
k = new Depot(name, ++kontozähler); k = new Depot(name, ++kontozähler);
Kunde ku = kunden.get(id); Kunde ku = kunden.get(id);
k.setKunde(ku); if (ku == null) {
throw new KundeNullException();
}
k.setKunde(ku.getId());
} }
konten.put(k.getKontonummer(), k); konten.put(k.getKontonummer(), k);
@ -70,14 +76,15 @@ public class Bank implements Serializable {
} }
public void kundeAnlegen(String vorname, String name, int alter, String wh) { public void kundeAnlegen(String vorname, String name, int alter, String wh) {
Kunde ku = new Kunde(vorname,name,alter,wh); Kunde ku = new Kunde(vorname, name, alter, wh);
kunden.put(ku.getId(), ku); kunden.put(ku.getId(), ku);
} }
public void kontoZuKunde(int kontonummer, int id) { public void kontoZuKunde(int kontonummer, int id) {
Kunde ku = kunden.get(id); Kunde ku = kunden.get(id);
Konto k = konten.get(kontonummer); Konto k = konten.get(kontonummer);
k.setKunde(ku); k.setKunde(ku.getId());
ku.kundeHatKonto(k.getKontonummer());
} }
public Collection<Kunde> getKundenListe() { public Collection<Kunde> getKundenListe() {
@ -85,14 +92,28 @@ public class Bank implements Serializable {
} }
public void aktieAnlegen(String aktienName, int kosten, int kontonummer) { public void aktieAnlegen(String aktienName, int kosten, int kontonummer) {
Aktien ak = new Aktien(aktienName,kosten,konten.get(kontonummer)); Aktien ak = new Aktien(aktienName, kosten, konten.get(kontonummer));
wertpapiere.put(ak.getId(), ak); wertpapiere.put(ak.getId(), ak);
} }
public Collection<Aktien> getAktienListe() { public Collection<Aktien> getAktienListe() {
return wertpapiere.values(); return wertpapiere.values();
} }
public Kunde findeKunde(int k) {
Kunde kunde = kunden.get(k);
return kunde;
}
public ArrayList<Konto> getKontenFromKunde(int kunde) {
Kunde k = kunden.get(kunde);
ArrayList<Konto> kontenKunde = new ArrayList<>();
ArrayList<Integer> kontonKunde = k.getKontennummern();
for (int i : kontonKunde) {
Konto ku = konten.get(i);
kontenKunde.add(ku);
}
return kontenKunde;
}
} }

View File

@ -35,4 +35,7 @@ public class Depot extends Girokonto implements Serializable {
return false; return false;
} }
public String toString() {
return "Depot-"+super.helpString();
}
} }

View File

@ -34,6 +34,10 @@ public class Girokonto extends Konto implements Serializable {
return false; return false;
} }
public String helpString() {
return super.toString();
}
@Override @Override
public String toString() { public String toString() {
return "Giro-" + super.toString(); return "Giro-" + super.toString();

View File

@ -7,13 +7,12 @@ public class Konto implements Serializable {
private int nummer; private int nummer;
protected long stand = 0; protected long stand = 0;
private String inhaber; private String inhaber;
protected Kunde kunde; protected int kundenid;
protected ArrayList<Kontobewegung> kontobewegungen; protected ArrayList<Kontobewegung> kontobewegungen;
public Konto(String inhaber, int kontozähler) { public Konto(String inhaber, int kontozähler) {
nummer = 1000 + kontozähler; nummer = 1000 + kontozähler;
this.inhaber = inhaber; this.inhaber = inhaber;
this.kontobewegungen = new ArrayList<>(); this.kontobewegungen = new ArrayList<>();
} }
@ -40,16 +39,16 @@ public class Konto implements Serializable {
kontobewegungen.add(new Kontobewegung(betrag, zweck, art, auftraggeber)); kontobewegungen.add(new Kontobewegung(betrag, zweck, art, auftraggeber));
} }
public boolean auszahlen(long betrag, String zweck, String art, String auftraggeber) { public boolean auszahlen(long betrag, String zweck, String art, String auftraggeber) throws NotEnoughMoneyException {
if (stand - betrag >= 0) { if (stand - betrag >= 0) {
stand -= betrag; stand -= betrag;
kontobewegungen.add(new Kontobewegung(betrag * -1, zweck, art, auftraggeber)); kontobewegungen.add(new Kontobewegung(betrag * -1, zweck, art, auftraggeber));
return true; return true;
} else {
throw new NotEnoughMoneyException();
} }
return false;
} }
public String[] getKontobewegungen() { public String[] getKontobewegungen() {
@ -73,8 +72,8 @@ public class Konto implements Serializable {
return saldo; return saldo;
} }
public void setKunde(Kunde k) { public void setKunde(int kid) {
this.kunde = k; this.kundenid = kid;
} }
} }

View File

@ -2,6 +2,7 @@ package de.hs_mannheim.informatik.bank.domain;
import static org.junit.jupiter.api.Assertions.*; import static org.junit.jupiter.api.Assertions.*;
import org.junit.jupiter.api.Disabled;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
class KontoTest { class KontoTest {
@ -25,6 +26,7 @@ class KontoTest {
testKontoEinUndAuszahlungUndSaldo(k, k2); testKontoEinUndAuszahlungUndSaldo(k, k2);
} }
private void testKontoEinUndAuszahlungUndSaldo(Konto k, Konto k2) { private void testKontoEinUndAuszahlungUndSaldo(Konto k, Konto k2) {
assertEquals("Mayer", k2.getInhaber()); assertEquals("Mayer", k2.getInhaber());
assertNotEquals(k.getKontonummer(), k2.getKontonummer()); assertNotEquals(k.getKontonummer(), k2.getKontonummer());

View File

@ -10,7 +10,7 @@ public class Kunde implements Serializable{
private String name; private String name;
private int alter; private int alter;
private String wohnort; private String wohnort;
private ArrayList<Konto> konten; private ArrayList<Integer> kontennummern;
public Kunde(String vorname, String name, int alter, String wohnort) { public Kunde(String vorname, String name, int alter, String wohnort) {
this.vorname = vorname; this.vorname = vorname;
@ -18,18 +18,19 @@ public class Kunde implements Serializable{
this.alter = alter; this.alter = alter;
this.wohnort = wohnort; this.wohnort = wohnort;
this.id++; this.id++;
kontennummern = new ArrayList<>();
} }
public void kundeHatKonte(Konto k) { public void kundeHatKonto(int k) {
konten.add(k); kontennummern.add(k);
} }
public int getId() { public int getId() {
return this.id; return this.id;
} }
public ArrayList<Konto> getKonten() { public ArrayList<Integer> getKontennummern() {
return konten; return kontennummern;
} }
@Override @Override

View File

@ -0,0 +1,17 @@
package de.hs_mannheim.informatik.bank.domain;
public class KundeNullException extends Exception {
public KundeNullException() {}
public KundeNullException(String message) {
super(message);
}
public KundeNullException(Throwable cause) {
super(cause);
}
public KundeNullException(String message, Throwable cause) {
super(message, cause);
}
}

View File

@ -0,0 +1,20 @@
package de.hs_mannheim.informatik.bank.domain;
public class NotEnoughMoneyException extends IllegalArgumentException {
public NotEnoughMoneyException() {
}
public NotEnoughMoneyException(String message) {
super(message);
}
public NotEnoughMoneyException(Throwable cause) {
super(cause);
}
public NotEnoughMoneyException(String message, Throwable cause) {
super(message, cause);
}
}

View File

@ -1,6 +1,7 @@
package de.hs_mannheim.informatik.bank.facade; package de.hs_mannheim.informatik.bank.facade;
import java.io.InvalidClassException; import java.io.InvalidClassException;
import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import de.hs_mannheim.informatik.bank.domain.Aktien; import de.hs_mannheim.informatik.bank.domain.Aktien;
@ -103,6 +104,10 @@ public class Banksystem {
bank.kundeAnlegen( vorname, name, alter, wh); bank.kundeAnlegen( vorname, name, alter, wh);
Persistenz.speichereBankDaten(this.bank, bank.getName()); Persistenz.speichereBankDaten(this.bank, bank.getName());
} }
public Collection<Kunde> getKunden(){
return bank.getKundenListe();
}
public String[] getKundenListe() { public String[] getKundenListe() {
Collection<Kunde> kunden = bank.getKundenListe(); Collection<Kunde> kunden = bank.getKundenListe();
@ -141,4 +146,17 @@ public class Banksystem {
bank.kaufeAktien(kontonummer,aktienId); bank.kaufeAktien(kontonummer,aktienId);
Persistenz.speichereBankDaten(this.bank, bank.getName()); Persistenz.speichereBankDaten(this.bank, bank.getName());
} }
public String[] getKundenKontos(int kunde) {
ArrayList<Konto> konten = bank.getKontenFromKunde(kunde);
String[] liste = new String[konten.size()];
int i = 0;
for (Konto k : konten) {
liste[i++] = k.toString();
}
return liste;
}
} }

View File

@ -0,0 +1,125 @@
package de.hs_mannheim.informatik.bank.gui;
import java.awt.Color;
import javax.swing.DefaultListModel;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JList;
import javax.swing.JPanel;
import javax.swing.JTextField;
import javax.swing.plaf.synth.ColorType;
import org.w3c.dom.css.RGBColor;
import de.hs_mannheim.informatik.bank.facade.Banksystem;
public class GUI {
private Banksystem bs;
public GUI(Banksystem bs) {
this.bs = bs;
hauptmenü();
}
private void hauptmenü() {
JFrame frame = new JFrame();
frame.setSize(500, 500);
frame.setTitle(bs.getBankname());
frame.setLayout(null);
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
JButton getKunde = new JButton("Alle Konten");
getKunde.setBounds(100, 50, 300, 50);
getKunde.addActionListener(e -> {
JFrame allKontos = new JFrame();
JPanel alleKontenPanel = new JPanel();
allKontos.setTitle(bs.getBankname());
allKontos.setSize(500, 500);
allKontos.add(alleKontenPanel);
String[] konten = bs.getKontenliste();
DefaultListModel<String> model = new DefaultListModel<>();
if (konten.length > 0) {
JLabel labelU = new JLabel("Alle Konten");
labelU.setBounds(50, 10, 100, 50);
// alleKontenPanel.add(labelU);
for (String s : konten) {
model.addElement(s);
}
JList<String> kontenJ = new JList<>(konten);
kontenJ.setBackground(new Color(119, 215, 239));
// labelU.setBounds(50,50,300,200);
alleKontenPanel.add(kontenJ);
} else {
}
allKontos.setVisible(true);
});
frame.add(getKunde);
JButton kontoAnlegen = new JButton("Konto anlegen");
kontoAnlegen.setBounds(100, 120, 300, 50);
kontoAnlegen.addActionListener(e -> {
JFrame kontosAnlegen = new JFrame();
JPanel kontenAnlegenPanel = new JPanel();
kontosAnlegen.setTitle(bs.getBankname());
kontosAnlegen.setSize(500, 500);
kontosAnlegen.add(kontenAnlegenPanel);
kontenAnlegenPanel.setLayout(null);
JLabel l_name = new JLabel("Name");
l_name.setBounds(50,50,100,50);
kontenAnlegenPanel.add(l_name);
JTextField t_name = new JTextField(20);
t_name.setBounds(200,50,100,30);
kontenAnlegenPanel.add(t_name);
JLabel l_konto = new JLabel("Konto");
l_konto.setBounds(50,150,100,50);
kontenAnlegenPanel.add(l_konto);
JTextField t_konto = new JTextField(20);
t_konto.setBounds(200,150,100,30);
kontenAnlegenPanel.add(t_konto);
JLabel l_kundenNr = new JLabel("Kunden Nummer");
l_kundenNr.setBounds(50,250,100,50);
kontenAnlegenPanel.add(l_kundenNr);
JTextField t_kundenNr = new JTextField(20);
t_kundenNr.setBounds(200,250,100,30);
kontenAnlegenPanel.add(t_kundenNr);
JButton kundeAnlegen = new JButton("Konto anlegen");
kundeAnlegen.setBounds(50,400,350,50);
kundeAnlegen.addActionListener(a -> {
try {
int kontonummer = bs.kontoAnlegen(t_name.getText(), Integer.parseInt(t_konto.getText()),
Integer.parseInt(t_kundenNr.getText()));
JLabel ko = new JLabel();
ko.setBounds(50,350,10,50);
ko.setText(Integer.toString(kontonummer));
kontenAnlegenPanel.add(ko);
} catch (NumberFormatException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (Exception e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
});
kontenAnlegenPanel.add(kundeAnlegen);
kontosAnlegen.setVisible(true);
});
frame.add(kontoAnlegen);
frame.setVisible(true);
}
}

View File

@ -1,7 +1,10 @@
package de.hs_mannheim.informatik.bank.ui; package de.hs_mannheim.informatik.bank.ui;
import java.util.Collection;
import java.util.Scanner; import java.util.Scanner;
import de.hs_mannheim.informatik.bank.domain.Kunde;
import de.hs_mannheim.informatik.bank.domain.KundeNullException;
import de.hs_mannheim.informatik.bank.facade.Banksystem; import de.hs_mannheim.informatik.bank.facade.Banksystem;
public class UI { public class UI {
@ -33,6 +36,7 @@ public class UI {
System.out.println("11 -> Aktie anlegen"); System.out.println("11 -> Aktie anlegen");
System.out.println("12 -> Alle Aktien anzeigen"); System.out.println("12 -> Alle Aktien anzeigen");
System.out.println("13 -> Aktien kaufen"); System.out.println("13 -> Aktien kaufen");
System.out.println("14 -> Kunden Konten anzeigen");
System.out.println("99 -> Beenden"); System.out.println("99 -> Beenden");
System.out.println(); System.out.println();
@ -81,6 +85,9 @@ public class UI {
case 13: case 13:
aktienKaufen(); aktienKaufen();
break; break;
case 14:
kundenKonten();
break;
case 99: case 99:
break mainloop; break mainloop;
} }
@ -95,6 +102,17 @@ public class UI {
} // hauptmenü } // hauptmenü
private void kundenKonten() {
System.out.println("Geben sie ihre KundenID ein: ");
int k = returnUserInput();
String[] list = bs.getKundenKontos(k);
if(list.length >0) {
for(String s : list) {
System.out.println(s);
}
}
}
private void aktienKaufen() throws Exception { private void aktienKaufen() throws Exception {
System.out.println("Geben sie die Kontonummer ein"); System.out.println("Geben sie die Kontonummer ein");
int kontonummer = returnUserInput(); int kontonummer = returnUserInput();
@ -169,17 +187,28 @@ public class UI {
} }
private void kontoAnlegen() throws Exception { private void kontoAnlegen() throws Exception {
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öchten Sie ein Sparkonto (1), Girokonto (2) oder ein Depot (3) anlegen?"); System.out.println("Möchten Sie ein Sparkonto (1), Girokonto (2) oder ein Depot (3) anlegen?");
int auswahl = returnUserInput(); int auswahl = returnUserInput();
System.out.println("Geben sie die Kundennummer ein(id)"); System.out.println("Geben sie ihre Kundennummer ein:");
int Kundennummer = returnUserInput(); int Kundennummer = returnUserInput();
try {
int kontonummer = bs.kontoAnlegen(name, auswahl, Kundennummer); int kontonummer = bs.kontoAnlegen(name, auswahl, Kundennummer);
System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt."); System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt.");
}catch(KundeNullException e) {
System.err.print("Der Kunde konnte nicht gefunden werden!");
}
} }
private void geldEinzahlen() throws Exception { private void geldEinzahlen() throws Exception {