jFxKasse/src/application/MainWindowController.java

701 lines
15 KiB
Java

package application;
import javafx.fxml.FXML;
import javafx.geometry.Insets;
import javafx.scene.Node;
import javafx.scene.control.Alert;
import javafx.scene.control.Alert.AlertType;
import javafx.scene.control.Button;
import javafx.scene.control.ButtonBar.ButtonData;
import javafx.scene.control.ButtonType;
import javafx.scene.control.Dialog;
import javafx.scene.control.TreeTableColumn;
import javafx.scene.control.TreeTableView;
import javafx.scene.control.TextField;
import javafx.scene.control.TreeItem;
import javafx.scene.control.TitledPane;
import javafx.scene.control.Tooltip;
import com.jfoenix.controls.JFXColorPicker;
//import com.sun.java.swing.action.NewAction;
import java.awt.Desktop;
import java.awt.Toolkit;
import java.awt.datatransfer.Clipboard;
import java.awt.datatransfer.StringSelection;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.URI;
import java.net.URISyntaxException;
import java.sql.DriverManager;
import java.util.Optional;
import java.util.Properties;
import javafx.application.Platform;
import javafx.beans.value.ChangeListener;
import javafx.beans.value.ObservableValue;
import javafx.event.ActionEvent;
import javafx.scene.control.Label;
import javafx.scene.control.PasswordField;
import javafx.scene.layout.AnchorPane;
import javafx.scene.layout.GridPane;
import javafx.util.Pair;
public class MainWindowController
{
private static final String String = null;
Toolkit toolkit = Toolkit.getDefaultToolkit();
Clipboard clipboard = toolkit.getSystemClipboard();
@FXML
private AnchorPane mainAnchorpane;
@FXML
private AnchorPane paneDB;
@FXML
private TreeTableView<tableData> tableCurrentOrder;
@FXML
private TreeTableColumn<tableData, String> columnQuantity;
@FXML
private TreeTableColumn<tableData, String> columnPosition;
@FXML
private TreeTableColumn<tableData, Integer> idSpalte01 = new TreeTableColumn<>(
"");
@FXML
private TreeTableView<tableData> jobsTreeTable;
@FXML
private TreeTableColumn<tableData, String> columnValue;
@FXML
private TreeTableColumn<tableData, String> columnState;
@FXML
private TreeTableColumn<tableData, String> columnPositions;
@FXML
private TreeTableColumn<tableData, String> columnTime;
@FXML
private TreeTableColumn<tableData, String> columnNumber;
@FXML
private TreeTableColumn<tableData, Integer> idSpalte02 = new TreeTableColumn<>(
"");
@FXML
private TreeTableView<tableData> entryTreeTable;
@FXML
private TreeTableColumn<tableData, String> columnColor;
@FXML
private TreeTableColumn<tableData, String> columnPrize;
@FXML
private TreeTableColumn<tableData, String> columnPositionsEdit;
@FXML
private TreeTableColumn<tableData, String> columnPosnumber;
@FXML
private TreeTableColumn<tableData, Integer> idSpalte03 = new TreeTableColumn<>(
"");
@FXML
private Button ueberbtn;
@FXML
private Button gridButton01;
@FXML
private Button gridButton02;
@FXML
private Button gridButton03;
@FXML
private Button gridButton04;
@FXML
private Button gridButton05;
@FXML
private Button gridButton06;
@FXML
private Button gridButton07;
@FXML
private Button gridButton08;
@FXML
private Button gridButton09;
@FXML
private Button gridButton10;
@FXML
private Button gridButton11;
@FXML
private Button gridButton12;
@FXML
private Button gridButton13;
@FXML
private Button gridButton14;
@FXML
private Button gridButton15;
@FXML
private Button gridButton16;
@FXML
private Button gridButton17;
@FXML
private Button gridButton18;
@FXML
private Button gridButton19;
@FXML
private Button gridButton20;
@FXML
private Button gridButton21;
@FXML
private Button gridButton22;
@FXML
private Button gridButton23;
@FXML
private Button gridButton24;
@FXML
private Button gridButton25;
@FXML
private Button btnDeleteSelectedPosition;
@FXML
private Button btnPrintBill;
@FXML
private Button btnLock;
@FXML
private Button btnReprintJob;
@FXML
private Button bntCancelJob;
@FXML
private Button btnCalcStats;
@FXML
private Button btnSaveEntry;
@FXML
private Button btnClearEntry;
@FXML
private Button btnCreateNewDatabase;
@FXML
private Button btnOpenFolder;
@FXML
private Label labelAllPrize;
@FXML
private Label labelJobCounter;
@FXML
private Label labelTime;
@FXML
private Label lableJobCount;
@FXML
private Label labelAvgJob;
@FXML
private Label lableAllValue;
@FXML
private Label lableNewPosition;
@FXML
private Label labelNewValue;
@FXML
private Label lableNewColor;
@FXML
private Label labelDBStatus;
@FXML
private Label labelDBName;
@FXML
private TitledPane titlePaneStats;
@FXML
private TextField tftNewPosition;
@FXML
private TextField tftNewValue;
@FXML
private TextField tftNewDBName;
@FXML
private JFXColorPicker colorChooser;
private Main main;
private DBController dbc;
private String filepathXMLLinux = System.getProperty("user.home")
+ "/bin/jFxKasse/config.xml"; // Pfad wo die XML liegt
private int id;
private String databaseName;
@FXML
TreeItem<tableData> root = new TreeItem<>(new tableData(0, "0", "0"));
Properties props = new Properties();
@FXML
public void ueberbtnAction(ActionEvent event)
{ // Öffnet den Über-Dialog
// Erstellt einen Dialog
Dialog<Pair<String, String>> dialog = new Dialog<>();
dialog.setTitle("Über jFxKasse");
dialog.setHeaderText(
"Informationen und Lizenzen - Version 0.7 - UI Techdemo");
// Erzeugt den Button
dialog.getDialogPane().getButtonTypes().addAll(ButtonType.OK);
// Erzeugt die Textfelder und Label
GridPane grid = new GridPane();
grid.setHgap(10);
grid.setVgap(10);
grid.setPadding(new Insets(20, 150, 10, 10));
grid.add(new Label("Datenbank: sqlite.org - Public Domain"
+ " \nUI Design: eclipse.org/efxclipse/install.html - Eclipse Public License 1.0"
+ " \nUI - Datenbank Integration: basierend auf Project-HomeFlix - github.com/Seil0/Project-HomeFlix - GPLv3 \n"
+ " \nMaintainer: hendrik.schutter@coptersicht.de"
+ " \n(c) 2018 Hendrik Schutter"), 0, 0);
dialog.getDialogPane().setContent(grid); // Setzt die GridPane auf die
dialog.setResizable(true); // DialogPane
dialog.showAndWait();
}
@FXML
public void btnOpenFolderAction(ActionEvent event) throws IOException
{
Runtime.getRuntime().exec("xdg-open " + System.getProperty("user.home") + "/bin/jFxKasse" );
}
@FXML
public void btnCreateNewDatabaseAction(ActionEvent event) throws Exception
{
System.out.println("Button!");
System.out.println(tftNewDBName.getText());
setDatabaseName(tftNewDBName.getText());
dbc.dbname = getDatabaseName();
dbc.verbindeDatenbank(); // Verbindet mit der Datenbank-Datei
dbc.erstelleTabellePositionen();
dbc.erstelleTabelleJobs();
try {
saveSettings(getDatabaseName());
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
setDBLabel();
initUI(); // Startet die UI
}
@FXML
public void btnSaveEntryAction(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void btnClearEntryAction(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void btnCalcStatsAction(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void btnReprintJobAction(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void bntCancelJobAction(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void btnLockAction(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void btnDeleteSelectedPositionAction(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void btnPrintBillAction(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton01Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton02Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton03Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton04Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton05Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton06Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton07Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton08Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton09Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton10Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton11Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton12Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton13Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton14Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton15Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton16Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton17Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton18Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton19Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton20Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton21Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton22Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton23Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton24Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void gridButton25Action(ActionEvent event)
{
System.out.println("Button!");
}
@FXML
public void fuelleTablle()
{ // Lädt die Datenbank in die Tabelle
// dbc.setSchluessel(schluessel);
for (int i = 0; i < dbc.ladeTabelle().size(); i++) {
tableData helpTableData = new tableData(
dbc.ladeTabelle().get(i).getID(),
dbc.ladeTabelle().get(i).getDatum(),
dbc.ladeTabelle().get(i).getKonto());
root.getChildren().add(new TreeItem<tableData>(helpTableData));
}
}
public void initUI()
{
System.out.println("initUI");
tftNewDBName.setText(getDatabaseName());
tableCurrentOrder.setRoot(root);
tableCurrentOrder.setShowRoot(false);
tableCurrentOrder.setEditable(false);
// Setzt die Textfelder
/*
idSpalte01.setCellValueFactory(
cellData -> cellData.getValue().getValue().idProperty().asObject());
columnQuantity.setCellValueFactory(
cellData -> cellData.getValue().getValue().datumProperty());
columnPosition.setCellValueFactory(
cellData -> cellData.getValue().getValue().kontoProperty());
tableCurrentOrder.getColumns().add(idSpalte01);
tableCurrentOrder.getColumns().get(2).setVisible(false);
tableCurrentOrder.getSelectionModel().selectedItemProperty()
.addListener(new ChangeListener<Object>() {
@Override
public void changed(ObservableValue<?> observable, Object oldVal,
Object newVal)
{
// last = selected; //for auto-play
int selected = tableCurrentOrder.getSelectionModel()
.getSelectedIndex(); // get selected item
id = idSpalte01.getCellData(selected); // Ausgewählte Spalte
try { // Setzt den entschlüsselten Inhalt in die Textfelder
// tf01.setText("Verschlüsseltes Passwort von " +
// crypo.entschluesseln(dbc.getKonto(id), schluessel) + " :
// " + dbc.getPasswort(id));
// tfNutzername.setText(crypo.entschluesseln(dbc.getNutzername(id),
// schluessel));
// tfEmail.setText(crypo.entschluesseln(dbc.getEmail(id),
// schluessel));
// tfPasswort.setText(crypo.entschluesseln(dbc.getPasswort(id),
// schluessel));
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
});
*/
}
public void setMain(Main main, DBController dbc)
{
this.main = main;
this.dbc = dbc;
}
public String getSystemDatum()
{ // Gibt das System-Datum zurück
java.util.Date now = new java.util.Date();
java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat(
"dd.MM.yyyy");
String heutigesDatum = sdf.format(now);
return heutigesDatum;
}
public void saveSettings(String databasename) throws Exception
{
OutputStream outputStream; // new output-stream
try {
props.setProperty("databasename", databasename); // writes dbname into
// property
outputStream = new FileOutputStream(filepathXMLLinux);
props.storeToXML(outputStream, "jFxKasse settings"); // writes new .xml
outputStream.close();
} catch (IOException e) {
}
}
public boolean loadSettings() throws Exception
{ // Ladt die Daten aus der XML
InputStream inputStream;
try {
inputStream = new FileInputStream(filepathXMLLinux);
props.loadFromXML(inputStream);
setDatabaseName(props.getProperty("databasename"));
// = crypo.entschluesseln(props.getProperty("key"),
// crypo.getProgrammSchluessel()); //liest schluessel von property
// base32Secret = crypo.entschluesseln(props.getProperty("TOTPkey"),
// crypo.getProgrammSchluessel()); //liest schluessel von property
inputStream.close();
return true;
} catch (IOException e) {
e.printStackTrace();
return false;
}
}
public void starteDB()
{ // Startet die Datenbank
dbc.verbindeDatenbank();
}
public String getDatabaseName()
{
return databaseName;
}
public void setDatabaseName(String NewDatabaseName)
{
databaseName = NewDatabaseName;
}
public void setDBLabel() throws Exception
{
if (loadSettings() == true) {
labelDBStatus
.setText("Geladene Datenbank: " + getDatabaseName() + ".db");
btnCreateNewDatabase.setDisable(true);
tftNewDBName.setDisable(true);
labelDBName.setTooltip(new Tooltip(
"Um eine neue Datenbank zu erzeugen muss die vorherige config.xml und "
+ getDatabaseName() + ".db gelöscht werden! Anwendung danach neustarten!"));
labelDBStatus.setTooltip(new Tooltip(
"Um eine neue Datenbank zu erzeugen muss die vorherige config.xml und "
+ getDatabaseName() + ".db gelöscht werden! Anwendung danach neustarten!"));
} else {
labelDBStatus.setText("Keine Datenbank gefunden!");
}
}
}