ceklog();
$this->load->library('pdf_dpk');
$this->load->library('rhrpt');
$this->load->library('rhlib');
#start check auth
$authorizationHeader['Authorization'] = str_replace('Bearer ', '', $_SERVER['HTTP_AUTHORIZATION']);
$login = @$this->my_usessionpublic->logged_in ? : false;
if ($authorizationHeader['Authorization'] && $login) {
if(strpos($_SERVER['HTTP_AUTHORIZATION'], 'Bearer ') !== 0){
$cek['status'] = false;
$cek['message'] = "Wrong number of segments";
$this->my_usessionpublic->set_userdata('pesan', $cek['message']);
echo json_encode($cek);
redirect('index.php/user/ext_logout');
die;
}
} else {
$cek['status'] = false;
$cek['message'] = "Please try login again.";
$this->my_usessionpublic->set_userdata('pesan', $cek['message']);
echo json_encode($cek);
redirect('index.php/user/ext_logout');
die;
}
$cek = check_auth($authorizationHeader, $login);
if(isset($cek['status']) && $cek['status'] == true){
// continue;
}
else{
$this->my_usessionpublic->set_userdata('pesan', $cek['message']);
echo json_encode($cek);
redirect('index.php/user/ext_logout');
die;
}
#end check auth
}
function ceklog() {
$user = $this->session->userdata("user_id1unla");
if($user==""){
redirect('user/login');
}
}
function get_bilangan($num){
return $this->rhlib->get_bilangan($num);
}
function get_par_val($table,$fieldName,$condition){
return $this->rhlib->get_par_val($table,$fieldName,$condition);
}
function get_row_pars($table,$fields,$condition){
return $this->rhlib->get_row_pars($table,$fields,$condition);
}
function get_data($thnmasuk,$jns_kelas,$kdprodi,$persen1,$kondisi1,$persen2,$kondisi2){
$persen1 = (isset($persen1)) ? intval($persen1):null;
$persen2 = (isset($persen2)) ? intval($persen2):null;
//descrip kondisi1
if ($kondisi1==1) {
$kondisi1 = '=';
} else if ($kondisi1==2) {
$kondisi1 = '<>';
} else if ($kondisi1==3) {
$kondisi1 = '>';
} else if ($kondisi1==4) {
$kondisi1 = '>=';
} else if ($kondisi1==5) {
$kondisi1 = '<';
} else if ($kondisi1==6) {
$kondisi1 = '<=';
}
//descrip kondisi2
if ($kondisi2==1) {
$kondisi2 = '=';
} else if ($kondisi2==2) {
$kondisi2 = '<>';
} else if ($kondisi2==3) {
$kondisi2 = '>';
} else if ($kondisi2==4) {
$kondisi2 = '>=';
} else if ($kondisi2==5) {
$kondisi2 = '<';
} else if ($kondisi2==6) {
$kondisi2 = '<=';
}
$KEDUA= $this->load->database('second', TRUE);
$query = $KEDUA->query("CALL sp_GetDpkDet (?,?,?,?,?,?,?)",array($thnmasuk,$jns_kelas,$kdprodi,$persen1,$kondisi1,$persen2,$kondisi2));
$result = array();
if ($query->num_rows() > 0) {
$result = $query->result();
}
return $result;
}
function get_rows_detdpk($thnmasuk,$jns_kelas,$kdprodi,$persen1,$kondisi1,$persen2,$kondisi2){
// data table
$data = $this->get_data($thnmasuk,$jns_kelas,$kdprodi,$persen1,$kondisi1,$persen2,$kondisi2);
$count = 0;
$count1 = 0;
$no = 1;
$total = 0;
$t_mhs = 0;
$t_blm = 0;
$t_tagih = 0;
$tot_tagih = 0;
$t_bayar = 0;
$tot_bayar = 0;
$t_sisa = 0;
$tot_sisa = 0;
$t_diskon = 0;
$tot_diskon = 0;
$rows = "";
foreach($data as $item)
{
$stlunas = $item->stlunas;
$t_tagih += $item->biaya;
$tot_tagih = number_format($t_tagih , 2 , ',' , '.' );
$t_bayar += $item->jmlbayar;
$tot_bayar = number_format($t_bayar , 2 , ',' , '.' );
$t_sisa += $item->sisa;
$tot_sisa = number_format($t_sisa , 2 , ',' , '.' );
$t_diskon += $item->diskon;
$tot_diskon = number_format($t_diskon , 2 , ',' , '.' );
if ($stlunas == 'Lunas'){
$count = 1;
$t_mhs += $count;
}
if ($stlunas == 'Belum Lunas'){
$count1 = 1;
$t_blm += $count1;
}
$rows .= "
".$no.". |
".$item->nim." |
".$item->nmmhs." |
".$item->nmstawalmhs." |
".$item->nmstaktivitasmhs." |
".$item->nmklsmhs." |
".number_format($item->biayapersmt , 2 , ',' , '.' )." |
".number_format($item->jmlbayar , 2 , ',' , '.' )." |
".number_format($item->persenbayarper , 0 , ',' , '.' )." % |
".number_format($item->sisaper , 2 , ',' , '.' )." |
".number_format($item->persensisaper , 0 , ',' , '.' )." % |
".$item->stlunasper." |
".number_format($item->diskon , 2 , ',' , '.' )." |
";
$no++;
}
$rows .= "
TOTAL LUNAS : $t_mhs org |
TOTAL BLM LUNAS : $t_blm org |
TOTAL (Rp.) : |
$tot_tagih |
$tot_bayar |
|
$tot_sisa |
|
|
$tot_diskon |
";
return $rows;
}
function get_det_dpk($thnmasuk,$jns_kelas,$kdprodi,$persen1,$kondisi1,$persen2,$kondisi2,$opt){
$row_tahun = $this->get_row_pars("tahun","tahun","tahun='$thnmasuk'");
$row_jnskelas = ($jns_kelas == 4) ? 'SEMUA':$this->get_row_pars("klsmhs","concat(kdklsmhs, '-', nmklsmhs) AS nmjnskls","idklsmhs='$jns_kelas'");
$row_prodi = $this->get_row_pars("prodi","nmprodi","kdprodi='$kdprodi'");
$tahun = $row_tahun->tahun;
$kelas = ($jns_kelas == 4) ? 'SEMUA':$row_jnskelas->nmjnskls;
$prodi = $row_prodi->nmprodi;
$angkatan_gjl = $tahun.'1';
$angkatan_gnp = $tahun.'2';
$smt1ganjil = $this->get_row_pars("vv_status_semester","*","kdstsemester='$angkatan_gjl'");
$smt1ganjilthn = $smt1ganjil->kdthnakademik;
$smt1ganjiljns = $smt1ganjil->nmjnssemester;
$smt1genap = $this->get_row_pars("vv_status_semester","*","kdstsemester='$angkatan_gnp'");
$smt1genapjns = $smt1genap->nmjnssemester;
$angkatan_plus = intval($tahun)+1;
$agktn_gjl = $angkatan_plus.'1';
$agktn_gnp = $angkatan_plus.'2';
$smt2ganjil = $this->get_row_pars("vv_status_semester","*","kdstsemester='$agktn_gjl'");
$smt2ganjilthn = $smt2ganjil->kdthnakademik;
$smt2ganjiljns = $smt2ganjil->nmjnssemester;
$smt2genap = $this->get_row_pars("vv_status_semester","*","kdstsemester='$agktn_gnp'");
$smt2genapjns = $smt2genap->nmjnssemester;
$optfull = $kondisi1.' '.$persen1.'% '.$opt.' '.$kondisi2.' '.$persen2.'%';
$optpart = $kondisi1.' '.$persen1.'%';
$opt = (!$kondisi2) ? $optpart:$optfull;
$this->pdf_dpk->SetCreator(PDF_CREATOR);
$datahead['code'] = 'LAP-DPK-DETAIL';
$this->pdf_dpk->addHeaderParams($datahead);
// set default header data
$this->pdf_dpk->SetHeaderData(PDF_HEADER_LOGO, PDF_HEADER_LOGO_WIDTH,PDF_HEADER_TITLE,PDF_HEADER_STRING);
$this->pdf_dpk->setPrintHeader(true);
$this->pdf_dpk->setPrintFooter(false);
// set header and footer fonts
$this->pdf_dpk->setHeaderFont(Array(PDF_FONT_NAME_MAIN, '', 10));
$this->pdf_dpk->setFooterFont(Array(PDF_FONT_NAME_DATA, '', PDF_FONT_SIZE_DATA));
// set default monospaced font
$this->pdf_dpk->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED);
// set margins
$this->pdf_dpk->SetMargins('5', '40', '20');
$this->pdf_dpk->SetHeaderMargin('10');
$this->pdf_dpk->SetFooterMargin(PDF_MARGIN_FOOTER);
// set auto page breaks
$this->pdf_dpk->SetAutoPageBreak(TRUE, PDF_MARGIN_BOTTOM);
// set image scale factor
$this->pdf_dpk->setImageScale(PDF_IMAGE_SCALE_RATIO);
// set some language-dependent strings (optional)
// ---------------------------------------------------------
// set font
$this->pdf_dpk->SetFont('helvetica', 'B', 8);
$this->pdf_dpk->SetCellPadding(0);
// add a page
$this->pdf_dpk->AddPage('L','F4');
$this->pdf_dpk->Write(0, 'LAPORAN DETAIL KEUANGAN DPK SAMPAI DENGAN '.$smt2ganjilthn.' - '.strtoupper($smt2genapjns), '', 0, 'C', true, 0, false, false, 0);
$this->pdf_dpk->Write(0, 'TAHUN MASUK / ANGKATAN '.$tahun, '', 0, 'C', true, 0, false, false, 0);
$this->pdf_dpk->Write(0, 'JENIS KELAS '.strtoupper($kelas), '', 0, 'C', true, 0, false, false, 0);
$this->pdf_dpk->Write(0, 'PROGRAM STUDI '.$prodi, '', 0, 'C', true, 0, false, false, 0);
$this->pdf_dpk->Write(0, 'TAHAPAN % BAYAR '.$opt, '', 0, 'C', true, 0, false, false, 0);
//$this->pdf_dpk->Cell(0,0,'',0,1,'L'); // untuk memberi space
$this->pdf_dpk->SetFont('helvetica', 'B', 10);
$rows_get_dpk = $this->get_rows_detdpk($thnmasuk,$jns_kelas,$kdprodi,$persen1,$kondisi1,$persen2,$kondisi2);
$tbl = <<
NO. |
NPM |
Nama Mahasiswa |
Status Masuk |
Status Mahasiswa |
Kelas |
Biaya Tagihan |
Bayar |
% Bayar |
Tunggakan |
% Tunggakan |
Status Bayar |
Diskon |
$rows_get_dpk
EOD;
$this->pdf_dpk->writeHTML($tbl,true,false,false,false);
$this->pdf_dpk->Output('rpt_det_dpk.pdf', 'I');
}
}
?>