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 = <<
$rows_get_dpk
NO. NPM Nama Mahasiswa Status Masuk Status Mahasiswa Kelas Biaya Tagihan Bayar % Bayar Tunggakan % Tunggakan Status Bayar Diskon

EOD; $this->pdf_dpk->writeHTML($tbl,true,false,false,false); $this->pdf_dpk->Output('rpt_det_dpk.pdf', 'I'); } } ?>