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 : 18.191.223.30
<?php
$main_src = substr($_SERVER['SCRIPT_FILENAME'], 0, strlen($_SERVER['SCRIPT_FILENAME']) - 7);
$pdf_writer_class = $main_src . "/tcpdf/tcpdf.php";
require_once($pdf_writer_class);
include_once("stringspliter.php");
class report_ra_qp_wise_student_count extends TCPDF
{
function DefaultConstructor($aobj_context)
{
session_start();
$this->aobj_context = $aobj_context;
$this->pdf = new TCPDF();
$this->pdf = $this;
$this->exdate = trim($this->aobj_context->mobj_data["exdate"]);
$this->session = trim($this->aobj_context->mobj_data["session"]);
$this->ip = $_SERVER["REMOTE_ADDR"];
$get_date = "select date_format(now(),'%d/%m/%Y %h:%i %p') as now_date";
// $get_date="select current_timestamp as now_date";
$obj = $this->aobj_context->mobj_db->GetRow($get_date);
$this->current_date = $obj['now_date'];
$this->collcode = $_SESSION['collcode'];
}
function Header()
{
session_start();
$FUNIVCODE = $_SESSION['FUNIVCODE'];
$this->pdf->Ln(5);
$img_path = $this->aobj_context->main_src . $this->photo_path;
if (!empty($this->photo_path) && file_exists($img_path)) {
$this->pdf->Image($img_path, 166, 50, 50);
}
if (!empty($this->pdf_logo_path)) {
$img_logo_path = $this->aobj_context->main_src . $this->pdf_logo_path;
$this->pdf->Image($img_logo_path, 10, 10, 23, 22);
}
$img_path2 = $this->aobj_context->main_src . "/img/logo2.jpg";
if (file_exists($img_path2)) {
$this->pdf->Image($img_path2, 170, 6, 23, 23);
}
$this->pdf->SetFont('Times', 'B', 15);
$this->pdf->cell(190, 7, $this->FUNIVNAME . "", "0", 1, "C");
$this->pdf->SetFont('Times', 'B', 10);
$this->pdf->cell(190, 7, $this->s_state, "0", 1, "C");
$this->pdf->SetFont('Times', 'B', 11);
$this->pdf->cell(190, 7, $this->college_details, "0", '1', "C");
$this->pdf->Cell(190, 7, "Bundle Dispatch Acknowledgement - " . $this->FEXAMDATE, "0", 1, "C");
$this->pdf->SetFont('Times', 'B', 12);
$this->pdf->Cell(65, 7, "Exam Date : " . $this->exdate, "0", 0, "L");
$this->pdf->SetFont('Times', 'BU', 12);
$this->pdf->Cell(60, 7, $this->copy, "0", 0, "C");
$this->pdf->SetFont('Times', 'B', 12);
if ($this->session == 'M') {
$session = "Morning Session";
} else {
$session = "After Noon Session";
}
$this->pdf->Cell(65, 7, "Session : " . $session, "0", 1, "R");
$this->pdf->Ln(2);
$this->pdf->SetFont('Times', '', 13);
}
function Footer()
{
$this->SetY(-15);
$this->pdf->SetFont('Times', '', 9);
$new_y = $this->pdf->GetY();
$this->pdf->Line(5, $new_y, 203, $new_y);
$this->Cell(140, 6, 'Printed - IP Address : ' . $this->ip . ", Date " . date('d/m/Y h:i:s A'), '0', 0, 'L');
$this->Cell(50, 6, 'Page ' . $this->PageNo() . ' of {nb}', 0, 1, 'R');
}
function formcolldata()
{
$get_coll_name = "select FUNIVNAME as 'FUNIVNAME',
FUNIVADD1 as 'state', pdf_logo_path From control";
$lobj_get_coll_name = $this->aobj_context->mobj_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'];
$get_data = "SELECT c.FCOLLCODE,
CONCAT(c.FCOLLCODE, ' - ', c.FCOLLNAME,', ',c.FTOWN) AS FCOLLNAME FROM college c
where c.FCOLLCODE='{$this->collcode}'";
$obj_student = $this->aobj_context->mobj_db->GetRow($get_data);
$this->college_details = $obj_student['FCOLLNAME'];
$this->degree_details = " College : {$this->FCOLLNAME}";
}
function GetFullQry()
{
$reporttype = "";
if ($this->session == 'M') {
$sess = 'AM';
} else {
$sess = 'PM';
}
// $get_data = "select c.FQPCODE, s.fsubname as FSSUBNAME,
// group_concat(concat(c.fbuno, ' (', c.ftotscript, ')') order by c.fbuno separator ', ') as fbundle,
// count(fbuno) as fbundlecnt,
// sum(ftotscript) as fpresentcnt
// from colldesp c inner join masqp s on c.fqpcode = s.fqpcode
// where c.fdoe = date_format(str_to_date('{$this->exdate}', '%d/%m/%Y'), '%Y-%m-%d')
// and fcollcode = '{$this->collcode}' and c.fsession = '{$sess}'
// group by c.fqpcode order by c.fqpcode";
$get_data = "select c.FQPCODE, s.fsubname as FSSUBNAME,
group_concat(concat(c.fbuno, ' (', c.ftotscript, ')') order by c.fbuno separator ', ') as fbundle,
count(fbuno) as fbundlecnt,
sum(ftotscript) as fpresentcnt, s.fvalcntr, m.fvalname, m.fvaladd1, m.fvaladd2, m.fvaladd3, m.fvaladd4, m.fvalcont
from colldesp c inner join (select fqpcode, fsubname, fvalcntr from subject group by fqpcode) s on c.fqpcode = s.fqpcode
inner join masvalcntr m on s.fvalcntr = m.fvalcntr
where c.fdoe = date_format(str_to_date('{$this->exdate}', '%d/%m/%Y'), '%Y-%m-%d')
and fcollcode = '{$this->collcode}' and c.fsession = '{$sess}'
group by c.fqpcode having fpresentcnt > 0
order by s.fvalcntr, c.fqpcode";
//var_dump($get_data);
$this->lobj_get_data = $this->aobj_context->mobj_db->GetAll($get_data);
/*
To take exam date from degree table
*/
$query = "select d.fexamdate from degree d inner join subject s on d.fdegree = s.fdegree
and s.fexamno = d.fexamno where s.fqpcode = '{$this->lobj_get_data[0]['FQPCODE']}'";
$this->degexdate = $this->aobj_context->mobj_db->GetRow($query);
$this->FEXAMDATE = $this->degexdate['fexamdate'];
}
function formData($copy)
{
$this->copy = $copy;
$this->pdf->SetMargins(10, 15, 10);
$this->pdf->AddPage();
$this->pdf->SetMargins(10, 15, 10);
$empty_cell_width = 1;
$sl_no = 1;
$k2 = 1;
$first = true;
$oldcntr = "";
$newcntr = "";
foreach ($this->lobj_get_data as $dk => $dv) {
if ($this->pdf->GetY() >= 250) {
$this->pdf->cell($empty_cell_width, 7, "", "", 0, "C");
$this->pdf->cell(190, 1, "", "T", 1, "C");
$this->pdf->AddPage();
$k2 = 1;
}
$newcntr = $dv['fvalcntr'];
if ($oldcntr != $newcntr) {
$this->pdf->SetFont('Times', 'B', 12);
if ($first == false) {
$this->pdf->cell(190, 1, "", "T", 1, "C");
$this->pdf->Ln(10);
$this->pdf->cell(95, 9, "Signature Chief Superintendent", 0, 0, "L");
$this->pdf->cell(95, 9, "Signature of Bundle Receiving Official", 0, 1, "R");
$this->pdf->AddPage();
}
$this->pdf->Ln(28);
$this->pdf->cell(190, 1, $dv['fvalname'], "LTR", 1, "L");
$this->pdf->cell(190, 1, $dv['fvaladd1'] . $dv['fvaladd2'], "LR", 1, "L");
$this->pdf->cell(190, 1, $dv['fvaladd3'] . $dv['fvaladd4'], "LR", 1, "L");
$this->pdf->cell(190, 1, $dv['fvalcont'], "LR", 1, "L");
$this->pdf->SetFont('Times', '', 12);
$sl_no = 1;
// }
// if ($first == true || $k2 == 1) {
// $this->pdf->Ln(25);
$this->pdf->SetFont('Times', 'B', 12);
// $this->pdf->Cell(190, 7, "", "0", 1, "C");
// $this->pdf->cell($empty_cell_width, 5, "", " ", 0, "C");
$this->pdf->cell(10, 5, "Sl.", "LTR", 0, "C");
$this->pdf->cell(16, 5, "QP", "LTR", 0, "C");
$this->pdf->cell(80, 5, "Subject / Paper Title", "LTR", 0, "C");
$this->pdf->cell(52, 5, "Bundle Nos.", "LTR", 0, "C");
$this->pdf->cell(16, 5, "No. of", "LTR", 0, "C");
$this->pdf->cell(16, 5, "No. of", "LTR", 1, "C");
// $this->pdf->cell($empty_cell_width, 7, "", " ", 0, "C");
$this->pdf->cell(10, 5, "No.", "LBR", 0, "C");
$this->pdf->cell(16, 5, "Code", "LBR", 0, "C");
$this->pdf->cell(80, 5, "", "LBR", 0, "C");
$this->pdf->cell(52, 5, "(Script Count)", "LBR", 0, "C");
$this->pdf->cell(16, 5, "Bundles", "LBR", 0, "C");
$this->pdf->cell(16, 5, "Scripts", "LBR", 1, "C");
$first = false;
}
$this->pdf->SetFont('Times', '', 12);
$subname = trim($dv['FSSUBNAME']);
$subnamearr = str_splitf($subname, 30);
//$subnamearr[1] = "English";
$nb = 0;
$nb = max($nb, NbLines(60, $dv['fbundle'], ''));
//var_dump($nb);die();
// $yH =12*$nb;
//var_dump($yH);
$yH = 0;
// $this->pdf->cell($empty_cell_width, $yH, "", " ", 0, "C");
$x = $this->pdf->GetX();
$y = $this->pdf->GetY();
$this->pdf->SetXY($x + 106, $y);
// $fill=false, $ln=1, $x='', $y='', $reseth=true, $stretch=0, $ishtml=false, $autopadding=true, $maxh=0, $valign='T', $fitcell=false
$this->pdf->Multicell(52, $yH, $dv['fbundle'], 'LRT', 'L');
$y1 = $this->pdf->GetY();
$yH = $y1 - $y + 2;
$this->pdf->SetXY($x, $y);
$this->pdf->cell(10, $yH, $sl_no, "LRT", 0, "C");
$this->pdf->cell(16, $yH, $dv['FQPCODE'], "LRT", 0, "C");
$this->pdf->cell(80, $yH, $subnamearr[0], "LRT", 0, "L");
$x = $this->pdf->GetX();
$y = $this->pdf->GetY();
$this->pdf->SetXY($x + 52, $y); //fbundlecnt
$this->pdf->cell(16, $yH, $dv['fbundlecnt'], "LRT", 0, "C");
$this->pdf->cell(16, $yH, $dv['fpresentcnt'], "LRT", 1, "C");
if ($k2 == 29) {
$this->pdf->cell(190, 1, "", "T", 0, "C");
}
if ($subnamearr[1] != '') {
$this->pdf->cell(10, 4, '', "LRB", 0, "C");
$this->pdf->cell(16, 4, '', "LRB", 0, "C");
$this->pdf->cell(80, 4, $subnamearr[1], "LRB", 0, "L");
$this->pdf->cell(52, 4, '', "LRB", 0, "C");
$this->pdf->cell(16, 4, '', "LRB", 0, "C");
$this->pdf->cell(16, 4, '', "LRB", 1, "C");
if ($k2 == 30) {
$this->pdf->cell(190, 1, "", "T", 0, "C");
}
}
$oldcntr = $dv['fvalcntr'];
$sl_no++;
$k2++;
}
// $this->pdf->cell($empty_cell_width, 7, "", "", 0, "C");
$this->pdf->cell(190, 1, "", "T", 1, "C");
$this->pdf->SetFont('Times', 'B', 12);
if (count($this->lobj_get_data) > 0) {
$this->pdf->Ln(10);
$this->pdf->cell(95, 9, "Signature Chief Superintendent", 0, 0, "L");
$this->pdf->cell(95, 9, "Signature of Bundle Receiving Official", 0, 1, "R");
// $this->pdf->SetFont('Times', '', 11);
// $this->pdf->cell(190, 9, "Note: Use this for in person submissions", 0, 1, "L");
}
}
function SendOutput()
{
$this->pdf->Output("QPBundleAcknowledgement.pdf", "D");
}
}
function GenerateBundleAck($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$class_obj = new report_ra_qp_wise_student_count();
//$class_obj->AliasNbPages();
$class_obj->DefaultConstructor($aobj_context);
$class_obj->GetFullQry();
$class_obj->formcolldata();
$class_obj->formData("University Copy");
$class_obj->formcolldata();
$class_obj->formData("College Copy");
$class_obj->SendOutput();
}
function NbLines($w, $txt, $pdf)
{
//Computes the number of lines a MultiCell of width w will take
$cw = &$pdf->CurrentFont['cw'];
if ($w == 0)
$w = $pdf->w - $pdf->rMargin - $pdf->x;
$wmax = ($w - 2 * $pdf->cMargin) * 1000 / $pdf->FontSize;
$s = str_replace("\r", '', $txt);
$nb = strlen($s);
if ($nb > 0 and $s[$nb - 1] == "\n")
$nb--;
$sep = -1;
$i = 0;
$j = 0;
$l = 0;
$nl = 1;
while ($i < $nb) {
$c = $s[$i];
if ($c == "\n") {
$i++;
$sep = -1;
$j = $i;
$l = 0;
$nl++;
continue;
}
if ($c == ' ')
$sep = $i;
$l += $cw[$c];
if ($l > $wmax) {
if ($sep == -1) {
if ($i == $j)
$i++;
} else
$i = $sep + 1;
$sep = -1;
$j = $i;
$l = 0;
$nl++;
} else
$i++;
}
return $nl;
}
|