crs.Manager_Report_DailyController.java Source code

Java tutorial

Introduction

Here is the source code for crs.Manager_Report_DailyController.java

Source

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package crs;

import com.itextpdf.text.Document;
import com.itextpdf.text.DocumentException;
import com.itextpdf.text.Element;
import com.itextpdf.text.Paragraph;
import com.itextpdf.text.Phrase;
import com.itextpdf.text.pdf.PdfPCell;
import com.itextpdf.text.pdf.PdfPTable;
import com.itextpdf.text.pdf.PdfWriter;
import static crs.CRS.getDailyRentalByBranch;
import static crs.CRS.getDailyRentalByCategory;
import static crs.CRS.getRentalByCategory;
import crs.classes.Rental;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.net.URL;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.ResourceBundle;
import java.util.logging.Level;
import java.util.logging.Logger;
import javafx.collections.FXCollections;
import javafx.collections.ListChangeListener;
import javafx.collections.ObservableList;
import javafx.event.ActionEvent;
import javafx.fxml.FXML;
import javafx.fxml.Initializable;
import javafx.scene.chart.BarChart;
import javafx.scene.chart.CategoryAxis;
import javafx.scene.chart.NumberAxis;
import javafx.scene.chart.XYChart;
import javafx.scene.control.Button;
import javafx.scene.control.DatePicker;
import javafx.scene.control.Label;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TableView;
import javafx.scene.control.TextField;
import javafx.scene.control.cell.PropertyValueFactory;
import javafx.scene.layout.Pane;
import javafx.stage.DirectoryChooser;
import javafx.stage.DirectoryChooserBuilder;

/**
 * FXML Controller class
 *
 * @author Ralph
 */
public class Manager_Report_DailyController implements Initializable {

    /**
     * Initializes the controller class.
     */
    @Override
    public void initialize(URL url, ResourceBundle rb) {
        // TODO
        barchart_dailyreport.setVisible(false);
        setPane(pane_Vehicle);
    }

    @FXML
    private DatePicker report_datepicker;
    @FXML
    private TableView table_vehicle;
    @FXML
    private TableView table_byloc;
    @FXML
    private TableView table_bycategory;
    @FXML
    private BarChart barchart_dailyreport;
    @FXML
    private CategoryAxis Caxis_dailyreport;
    @FXML
    private NumberAxis Naxis_dailyreport;
    @FXML
    private Pane pane_summary;
    @FXML
    private Pane pane_Vehicle;
    @FXML
    private Button button_download;
    @FXML
    private Button button_summary;
    @FXML
    private Label label_result;
    @FXML
    private TextField totalField;

    static ArrayList<Rental> bdata;
    static ArrayList<Rental> cdata;
    static ArrayList<crs.classes.Vehicle> Vlist;

    @FXML
    private void onChangeDate(ActionEvent event) {
        String date = report_datepicker.getValue().toString();
        setPane(pane_Vehicle);
        Vlist = CRS.getDailyRental(date, -1);
        bdata = getDailyRentalByBranch(date);
        cdata = getRentalByCategory(date);
    }

    private void setPane(Pane pane) {
        pane_summary.setVisible(false);
        pane_Vehicle.setVisible(false);

        pane_Vehicle.setLayoutX(2000);
        pane_Vehicle.setLayoutY(1000);
        pane_summary.setLayoutX(2000);
        pane_summary.setLayoutY(1000);

        pane.setVisible(true);
        pane.setLayoutX(20);
        pane.setLayoutY(totalField.getLayoutY() + 20);

    }

    @FXML
    private void onView(ActionEvent event) {
        if (report_datepicker.getValue() == null)
            return;

        setPane(pane_Vehicle);
        setTable(Vlist, table_vehicle);
        totalField.setText(Vlist.size() + "");

    }

    @FXML
    private void onSummary(ActionEvent event) {
        if (report_datepicker.getValue() == null)
            return;

        String date = report_datepicker.getValue().toString();

        setPane(pane_summary);
        HashMap<String, Integer> data = getDailyRentalByCategory(date);
        setChart(data, barchart_dailyreport, Caxis_dailyreport, Naxis_dailyreport);

        setTableR(bdata, table_byloc);
        setTableC(cdata, table_bycategory);

    }

    @FXML
    private void onDownload(ActionEvent event) {
        if (report_datepicker.getValue() == null)
            return;
        String filename = report_datepicker.getValue().toString() + "_DailyRental.pdf";
        DirectoryChooserBuilder builder = DirectoryChooserBuilder.create();
        builder.title("Hello World");
        String cwd = System.getProperty("user.dir");
        File file = new File(cwd);
        builder.initialDirectory(file);
        DirectoryChooser chooser = builder.build();
        File chosenDir = chooser.showDialog(null);
        if (chosenDir != null) {
            System.out.println(chosenDir.getAbsolutePath());
        } else {
            System.out.print("no directory chosen");
        }

        Document document = new Document();
        try {
            PdfWriter.getInstance(document, new FileOutputStream(chosenDir.getAbsolutePath() + "/" + filename));

            document.open();
            Paragraph paragraph = new Paragraph();
            paragraph.add("Daily Report of " + report_datepicker.getValue().toString());
            paragraph.setAlignment(Element.ALIGN_CENTER);
            paragraph.setSpacingAfter(40);
            document.add(paragraph);
            document.add(createPDFTableVehicle(Vlist));
            paragraph.clear();
            paragraph.add("  ");
            paragraph.setSpacingAfter(20);
            document.add(paragraph);
            document.add(createPDFTableByCategory(cdata));

            paragraph.setSpacingAfter(20);
            document.add(paragraph);
            document.add(createPDFTableByBranch(bdata));
            document.close();
            label_result.setText("Download successfully");
            label_result.setVisible(true);
        } catch (FileNotFoundException ex) {
            Logger.getLogger(Manager_ReportController.class.getName()).log(Level.SEVERE, null, ex);
        } catch (DocumentException ex) {
            Logger.getLogger(Manager_ReportController.class.getName()).log(Level.SEVERE, null, ex);
        }

    }

    public static PdfPTable createPDFTableVehicle(ArrayList<crs.classes.Vehicle> list) {

        PdfPTable table = new PdfPTable(5);

        PdfPCell cell;
        // now we add a cell with rowspan 2
        /*cell = new PdfPCell(new Phrase("Cell with rowspan 2"));
        cell.setRowspan(2);
        table.addCell(cell);*/
        // we add the four remaining cells with addCell()
        table.addCell("Vlicense");
        table.addCell("Vname");
        table.addCell("Branch Location");
        table.addCell("Category");
        table.addCell("Vtype name");
        for (int i = 0; i < list.size(); i++) {
            table.addCell(list.get(i).Vlicense + "");
            table.addCell(list.get(i).Vname + "");
            table.addCell(list.get(i).Branch_location + "");
            table.addCell(list.get(i).Vtype_name + "");
            table.addCell(list.get(i).category + "");
        }
        return table;
    }

    public static PdfPTable createPDFTableByCategory(ArrayList<crs.classes.Rental> list) {
        PdfPTable table = new PdfPTable(2);
        PdfPCell cell;
        table.addCell("Category");
        table.addCell("Number");
        for (int i = 0; i < list.size(); i++) {
            table.addCell(list.get(i).typename);
            table.addCell(list.get(i).number + "");
        }
        return table;
    }

    public static PdfPTable createPDFTableByBranch(ArrayList<crs.classes.Rental> list) {
        PdfPTable table = new PdfPTable(2);
        PdfPCell cell;
        table.addCell("Branch");
        table.addCell("Number");
        for (int i = 0; i < list.size(); i++) {
            table.addCell(list.get(i).branchLoc);
            table.addCell(list.get(i).number + "");
        }
        return table;
    }

    private void setTable(ArrayList<crs.classes.Vehicle> list, TableView<crs.classes.Vehicle> table) {

        TableColumn<crs.classes.Vehicle, String> VIDCol = new TableColumn<>("Vlicense");
        VIDCol.setMinWidth(90);
        TableColumn<crs.classes.Vehicle, String> VtypeCol = new TableColumn<>("category");
        VtypeCol.setMinWidth(70);
        TableColumn<crs.classes.Vehicle, String> typeCol = new TableColumn<>("Vtype_name");
        typeCol.setMinWidth(90);
        TableColumn<crs.classes.Vehicle, String> nameCol = new TableColumn<>("Vname");
        nameCol.setMinWidth(90);
        TableColumn<crs.classes.Vehicle, String> LocationCol = new TableColumn<>("Branch_location");
        LocationCol.setMinWidth(200);

        table.getColumns().clear();
        table.getColumns().addAll(VIDCol, nameCol, LocationCol, VtypeCol, typeCol);
        if (list.size() == 0) {
            return;
        }
        ObservableList<crs.classes.Vehicle> myData = FXCollections.observableArrayList();
        for (int i = 0; i < list.size(); i++) {
            myData.add(list.get(i));
        }

        VIDCol.setCellValueFactory(new PropertyValueFactory<crs.classes.Vehicle, String>("Vlicense"));
        VtypeCol.setCellValueFactory(new PropertyValueFactory<crs.classes.Vehicle, String>("Vtype_name"));
        typeCol.setCellValueFactory(new PropertyValueFactory<crs.classes.Vehicle, String>("category"));
        nameCol.setCellValueFactory(new PropertyValueFactory<crs.classes.Vehicle, String>("Vname"));
        LocationCol.setCellValueFactory(new PropertyValueFactory<crs.classes.Vehicle, String>("Branch_location"));

        table.setItems(myData);

    }

    private void setTableR(ArrayList<Rental> list, TableView table) {

        TableColumn<crs.classes.Rental, String> branchCol = new TableColumn<>("branch");
        branchCol.setMinWidth(90);
        TableColumn<crs.classes.Rental, String> numberCol = new TableColumn<>("number");
        numberCol.setMinWidth(70);

        table.getColumns().clear();
        table.getColumns().addAll(branchCol, numberCol);
        if (list.size() == 0) {
            return;
        }
        ObservableList<crs.classes.Rental> myData = FXCollections.observableArrayList();
        for (int i = 0; i < list.size(); i++) {
            myData.add(list.get(i));
        }

        branchCol.setCellValueFactory(new PropertyValueFactory<crs.classes.Rental, String>("branchLoc"));
        numberCol.setCellValueFactory(new PropertyValueFactory<crs.classes.Rental, String>("number"));

        table.setItems(myData);

    }

    private void setTableC(ArrayList<Rental> list, TableView table) {

        TableColumn<crs.classes.Rental, String> branchCol = new TableColumn<>("category");
        branchCol.setMinWidth(90);
        TableColumn<crs.classes.Rental, String> numberCol = new TableColumn<>("number");
        numberCol.setMinWidth(70);

        table.getColumns().clear();
        table.getColumns().addAll(branchCol, numberCol);
        if (list.size() == 0) {
            return;
        }
        ObservableList<crs.classes.Rental> myData = FXCollections.observableArrayList();
        for (int i = 0; i < list.size(); i++) {
            myData.add(list.get(i));
        }

        branchCol.setCellValueFactory(new PropertyValueFactory<crs.classes.Rental, String>("typename"));
        numberCol.setCellValueFactory(new PropertyValueFactory<crs.classes.Rental, String>("number"));

        table.setItems(myData);

    }

    private void setChart(HashMap<String, Integer> data, BarChart barchart, CategoryAxis caxis, NumberAxis naxis) {

        //barchart_dailyreport.setTitle("");     
        //caxis.setLabel("Category");       
        naxis.setLabel("Number");

        XYChart.Series series1 = new XYChart.Series();
        //series1.setName("Rent number");  
        int i = 0;
        for (String temp : data.keySet()) {
            series1.getData().add(new XYChart.Data(temp, data.get(temp)));
        }
        barchart_dailyreport.getData().addAll(series1);

    }

}