0xV3NOMx
Linux ip-172-26-7-228 5.4.0-1103-aws #111~18.04.1-Ubuntu SMP Tue May 23 20:04:10 UTC 2023 x86_64



Your IP : 52.14.176.111


Current Path : /var/www/html/univadmin/Reports/
Upload File :
Current File : /var/www/html/univadmin/Reports/duplicatePaymentReport.php

<?php
$main_src = substr($_SERVER['SCRIPT_FILENAME'], 0, strlen($_SERVER['SCRIPT_FILENAME']) - 7);
$pdf_writer_class = $main_src . "/tarka_pdf_latest/fpdf.php";
require_once $pdf_writer_class;
ini_set('max_execution_time', 0);
class GenerateFeeSummaryReport extends FPDF
{

    public function DefaultConstructor($aobj_context)
    {
        include_once $aobj_context->main_src . "/src/format.php";
        $this->aobj_context = $aobj_context;
        $this->pdf = new FPDF();
        $this->pdf = $this;
        session_start();
        $this->ip = $_SERVER["REMOTE_ADDR"];
        $get_date = "select date_add(date_add(now(),INTERVAL 13 hour),interval 30 minute) as now_date";
        $obj = $this->aobj_context->pobj_db->GetRow($get_date);
        $this->current_date = $obj['now_date'];

        $this->cntr_from = substr("0000000000" . $aobj_context->mobj_data["cntr_from"], -4);
        $this->cntr_to = substr("ZZZZZZZZZZ" . $aobj_context->mobj_data["cntr_end"], -4);

        $this->degree_from = substr("0000000000" . $aobj_context->mobj_data["degree_from"], -5);
        $this->degree_to = substr("ZZZZZZZZZZ" . $aobj_context->mobj_data["degree_to"], -5);

        $this->examno_from = $aobj_context->mobj_data["examno_from"];
        $examnoStr = strtoupper($this->examno_from);
        $splitexamno = str_split($examnoStr);
        $this->examno = implode(",", $splitexamno);
        // var_dump($this->examno);

        $this->exam_type = $aobj_context->mobj_data["exam_type"];
        $this->exam_year = $aobj_context->mobj_data["exam_year"];
        $this->univcode = $aobj_context->mobj_data["univcode"];

// var_dump($this->exam_type, $this->exam_year);
        //var_dump($this->degree_to);
        $this->Degree = $aobj_context->mobj_data["Degree"];
        $this->Screentype = $aobj_context->mobj_data["Screentype"];
        // var_dump($this->Screentype);
        $this->ReportType = $aobj_context->mobj_data["ReportType"];

    }

    public function Header()
    {
         if ($this->Screentype == "Duplicate Payment Report") {
            $img_path = $this->aobj_context->main_src . "/img/{$this->univcode}_logo.jpg";
            if (!empty($this->pdf_logo_path) && file_exists($img_path)) {

                $this->pdf->Image($img_path, 10, 10, 20);
            } // $this->pdf->Image($img_path,10,10,20);
        }
        $this->pdf->SetFont('Times', 'B', 15);
        $this->pdf->cell(0, 7, "" . $this->FUNIVNAME, "0", 1, "C");
        $this->pdf->SetFont('Times', '', 8);
        $this->pdf->cell(0, 4, $this->s_state, "0", 0, "C");
        $this->pdf->SetFont('Times', '', 10);
        $this->pdf->Cell(-20, 4, "Page {$this->pdf->PageNo()}/{nb}", 0, 1, 'C');
        $this->pdf->SetFont('Times', 'B', 10);

        if ($this->Screentype == 'Duplicate Payment Report') {
            $this->pdf->SetTitle("Multiple Payment Report");

            $this->pdf->cell(0, 5, "Multiple Payment Report", "0", 1, "C");
        } 
        //$this->pdf->cell(0,5,$this->ReportType,"0",1,"C");
        $this->pdf->cell(0, 5, "Degree Group:" . " " . $this->Degree, "0", 1, "C");

        $this->pdf->cell(0, 5, "College Code Range :" . " " . $this->cntr_from . " " . "to" . " " . $this->cntr_to, "0", 1, "C");
        $this->pdf->cell(0, 5, "Degree Range :" . " " . $this->degree_from . " " . "to" . " " . $this->degree_to, "0", 1, "C");

        // $this->pdf->cell(0, 5, "Exam Year/ Type:" . " " . $this->exam_year . '/' . $this->exam_type, "0", 1, "C");
        // $this->pdf->cell(0, 5, "Exam No. :" . " " . $this->examno, "0", 1, "C");
        
    }

    public function Footer()
    {

        if ($this->Screentype == "Exam Application Fee Summary") {
            $this->SetY(-15);
            $this->pdf->SetFont('Times', 'B', 8);
            $new_y = $this->pdf->GetY();
            $this->pdf->Line(8, $new_y, 290, $new_y);
            $this->pdf->Ln(2);
            $this->Cell(180, 6, 'Printed   : IP Address : ' . $this->ip . " Date " . $this->current_date, '0', 0, 'L');
        } else if ($this->Screentype == "Admission Apllication Fee Summary") {
            $this->SetY(-15);
            $this->pdf->SetFont('Times', 'B', 8);
            $new_y = $this->pdf->GetY();
            $this->pdf->Line(5, $new_y, 203, $new_y);
            $this->pdf->Ln(2);
            $this->Cell(140, 6, 'Printed   : IP Address : ' . $this->ip . " Date " . $this->current_date, '0', 0, 'L');

        }
    }

    public function formcolldata()
    {
        $get_coll_name = "select FUNIVNAME as 'FUNIVNAME',
		FUNIVADD1 as 'state', pdf_logo_path From control";
        $lobj_get_coll_name = $this->aobj_context->pobj_db->GetRow($get_coll_name);
        $this->FUNIVNAME = $lobj_get_coll_name['FUNIVNAME'];
        $this->s_state = $lobj_get_coll_name['state'];
        $this->f_year = $lobj_get_coll_name['f_year'];
        $this->pdf_logo_path = $lobj_get_coll_name['pdf_logo_path'];

    }
    public function dupTblHeader()
    {

        $this->pdf->SetFont('Times', 'B', 10);

        $this->pdf->Cell(8, 5, "Sl.", "LRT", 0, "C");
        $this->pdf->Cell(15, 5, "College", "LRT", 0, "C");
        $this->pdf->Cell(15, 5, "Degree", "LRT", 0, "C");
        $this->pdf->Cell(20, 5, "Reg. No.", "LRT", 0, "C");
        $this->pdf->Cell(60, 5, "Student", "LRT", 0, "C");
        $this->pdf->Cell(25, 5, "Application", "LRT", 0, "C");
        $this->pdf->Cell(15, 5, "Amount", "LRT", 0, "C");
        $this->pdf->Cell(25, 5, "Payment", "LRT", 0, "C");
        $this->pdf->Cell(20, 5, 'Ack', "LRT", 0, "C");
        $this->pdf->Cell(80, 5, "Payment", "LRT", 1, "C");

        // $this->pdf->SetFont('Times','B',10);
        $this->pdf->Cell(8, 5, "No.", "LRB", 0, "C");
        $this->pdf->Cell(15, 5, "Code", "LRB", 0, "C");
        $this->pdf->Cell(15, 5, "", "LRB", 0, "C");
        $this->pdf->Cell(20, 5, "", "LRB", 0, "R");
        $this->pdf->Cell(60, 5, "Name", "LRB", 0, "C");
        $this->pdf->Cell(25, 5, "No.", "LRB", 0, "C");
        $this->pdf->Cell(15, 5, "Paid", "LRB", 0, "C");
        $this->pdf->Cell(25, 5, "Type", "LRB", 0, "C");
        $this->pdf->Cell(20, 5, 'Date', "LBR", 0, "C");
        $this->pdf->Cell(80, 5, "Remarks", "LRB", 1, "C");

    }
    public function formdata()
    {
        //arr of ffreshexam A to H
        // $examnoarr  = "ABCDEFGH";
        $examnoStr = strtoupper($this->examno_from);
        $splitexamno = str_split($examnoStr);
        // var_dump($splitexamno);

        $examno = implode("','", $splitexamno);
        // var_dump($examno);
        //  if ($this->Screentype == 'Duplicate Payment Report') {

            if ($this->exam_type == '2' && $this->exam_year == '2018') {
                $tbl = 'appcandsum_' . $this->exam_year . $this->exam_type;
                // var_dump($tbl);
                $lobj_fee_data = "select a.fcollcode, a.fdegree, a.fregno, s.fname, a.appno,date_format(a.fackdate, '%d/%m/%Y') as fackdate,
			if(a.fpaymentype= 'Other Banks',a.fpaygateway,a.fpaymentype) as paymentType, a.fpaymentremarks, a.ftotalfee from $tbl a
			inner join degree d on a.fdegree=d.fdegree and a.fexamno=d.fexamno inner join student s on a.fregno = s.fregno and a.fdegree = s.fdegree
			where a.fpaymentstatus='success' and
			a.fregno in (select fregno from $tbl where fpaymentstatus='success' and fpaymentype != 'college bank' group by fregno having count(fregno) > 1)
			and a.fpaymentype != 'college bank'
			and a.fdegree between '{$this->degree_from}' and '{$this->degree_to}' and a.fdegree in (select distinct fdegree from degree where
			fdeggrp = '{$this->Degree}')
			and a.fcollcode between '{$this->cntr_from}' and '{$this->cntr_to}' and a.ffreshexam IN ('{$examno}')
			order by a.fcollcode, a.fdegree, a.fregno";

            } else {
                $lobj_fee_data = "select a.fcollcode, a.fdegree, a.fregno, s.fname, a.appno,date_format(a.fackdate, '%d/%m/%Y') as fackdate,
				if(a.fpaymentype= 'Other Banks',a.fpaygateway,a.fpaymentype) as paymentType, a.fpaymentremarks,a.ftotalfee from appcandsum a
				inner join degree d on a.fdegree=d.fdegree and a.fexamno=d.fexamno inner join student s on a.fregno = s.fregno and a.fdegree = s.fdegree
				where a.fpaymentstatus='success' and
				a.fregno in (select fregno from appcandsum where fpaymentstatus='success' group by fregno having count(fregno) > 1)
				and a.fpaymentype != 'college bank'
				and a.fdegree between '{$this->degree_from}' and '{$this->degree_to}' and a.fdegree in (select distinct fdegree from degree where
				fdeggrp = '{$this->Degree}')
				and a.fcollcode between '{$this->cntr_from}' and '{$this->cntr_to}' and a.ffreshexam IN ('{$examno}')
				order by a.fcollcode, a.fdegree, a.fregno";
            }
        // }

        // var_dump($lobj_fee_data);

        //==build report==//
        $lobj_get_fee_data = $this->aobj_context->pobj_db->GetAll($lobj_fee_data);
        // var_dump($lobj_get_fee_data);
        // if ($this->Screentype == 'Duplicate Payment Report') {
            $this->pdf->SetMargins(8, 13);
            $this->pdf->SetFont('Times', 'B', 10);
            $this->pdf->AddPage('L');

            $this->dupTblHeader();
            $oldcode = '';
            $count = 0;
            $nxt = 0;
            // $newcode=$lobj_get_fee_data[0]['fregno'];

            foreach ($lobj_get_fee_data as $key => $value) {

                $newcode = $value['fregno'];

                $this->pdf->SetFont('Times', '', 10);
                $x = $this->pdf->GetX();
                $y = $this->pdf->GetY();
                $this->pdf->SetX($x + 203);
                $this->pdf->MultiCell(80, 6, $value['fpaymentremarks'] . "\n", "1", "L");
                $y1 = $this->pdf->GetY();
                if ($y > 179) {
                    $this->dupTblHeader();
                }

                $h = $y1 - $y;
                $this->pdf->SetXY($x, $y);

                if ($newcode !== $oldcode) {

                    $sl_no++;

                    $this->pdf->SetFont('Times', '', 10);
                    $this->pdf->Cell(8, $h, $sl_no, "LRT", 0, "C");
                    $this->pdf->Cell(15, $h, $value['fcollcode'], "LRT", 0, "C");
                    $this->pdf->Cell(15, $h, $value['fdegree'], "LRT", 0, "C");
                    $this->pdf->Cell(20, $h, $value['fregno'], "LRT", 0, "C");
                    $this->pdf->Cell(60, $h, ucwords(strtolower($value['fname'])), "LRT", 0, "L");
                    $this->pdf->Cell(25, $h, $value['appno'], "1", 0, "C");
                    $this->pdf->Cell(15, $h, $value['ftotalfee'], "1", 0, "C");
                    $this->pdf->Cell(25, $h, $value['paymentType'], "1", 0, "L");
                    $this->pdf->Cell(20, $h, $value['fackdate'], "1", 1, "L");

                    $oldcode = $value['fregno'];
                    if ($this->pdf->getY() > 173) {
                        $this->pdf->Cell(170, 1, " ", "T", 1, "C");
                        $this->pdf->AddPage('L');

                        $this->pdf->SetFont('Times', 'B', 10);
                        $this->dupTblHeader();
                    }
                    // var_dump($oldcode);
                } else {
                    $this->pdf->SetFont('Times', '', 10);
                    $this->pdf->Cell(8, $h, "", "LR", 0, "C");
                    $this->pdf->Cell(15, $h, "", "LR", 0, "C");
                    $this->pdf->Cell(15, $h, "", "LR", 0, "C");
                    $this->pdf->Cell(20, $h, "", "LR", 0, "C");
                    // $this->pdf->Cell(120,6,"","LBR",0,"C");
                    $this->pdf->Cell(60, $h, "", "LR", 0, "L");
                    $this->pdf->Cell(25, $h, $value['appno'], "1", 0, "C");
                    $this->pdf->Cell(15, $h, $value['ftotalfee'], "1", 0, "C");
                    $this->pdf->Cell(25, $h, $value['paymentType'], "1", 0, "L");
                    $this->pdf->Cell(20, $h, $value['fackdate'], "1", 1, "L");

                    if ($this->pdf->getY() > 173) {
                        $this->pdf->Cell(170, 1, " ", "T", 1, "C");
                        $this->pdf->AddPage('L');

                        $this->pdf->SetFont('Times', 'B', 10);
                        $this->dupTblHeader();

                    }
                }

                if ($this->pdf->getY() > 173) {
                    $this->pdf->SetFont('Times', 'B', 10);
                    $this->pdf->AddPage('L');

                    $this->dupTblHeader();
                }
            }
            $this->pdf->Cell(170, 1, " ", "T", 1, "C");
        // }
    }

    public function SendOutput()
    {
        $this->pdf->Output("fee_summary.{$this->Screentype}.pdf", "I");
    }

}
function generateMultipleFeeReport($aobj_context)
{
    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
    // var_dump($aobj_context);

    $class_obj = new GenerateFeeSummaryReport();
    $class_obj->AliasNbPages();
    $class_obj->DefaultConstructor($aobj_context);
    $class_obj->Header();

    $class_obj->formcolldata();
    $class_obj->formdata();
    $class_obj->SendOutput();
}
function moneyFormatIndia($num)
{
    $explrestunits = "";
    if (strlen($num) > 3) {
        $lastthree = substr($num, strlen($num) - 3, strlen($num));
        $restunits = substr($num, 0, strlen($num) - 3); // extracts the last three digits
        $restunits = (strlen($restunits) % 2 == 1) ? "0" . $restunits : $restunits; // explodes the remaining digits in 2's formats, adds a zero in the beginning to maintain the 2's grouping.
        $expunit = str_split($restunits, 2);
        for ($i = 0; $i < sizeof($expunit); $i++) {
            // creates each of the 2's group and adds a comma to the end
            if ($i == 0) {
                $explrestunits .= (int) $expunit[$i] . ","; // if is first value , convert into integer
            } else {
                $explrestunits .= $expunit[$i] . ",";
            }
        }
        $thecash = $explrestunits . $lastthree;
    } else {
        $thecash = $num;
    }
    return $thecash; // writes the final format where $currency is the currency symbol.
}