ceklog();
$this->load->library('pdf_transkrip');
$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 squery($query){
$KEDUA= $this->load->database('second', TRUE);
$query = $KEDUA->query($query);
$row= '';
if ($query->num_rows() != 0)
{
$row = $query->row();
}
return $row;
}
function nm_field2($column,$tbl,$whereb, $wherea){
$KEDUA= $this->load->database('second', TRUE);
$q = "SELECT ".$column." as nm FROM ".$tbl." where ".$whereb." = '".$wherea."' " ;
$query = $KEDUA->query($q);
$nm= '';
if ($query->num_rows() != 0)
{
$row = $query->row();
$nm=$row->nm;
}
return $nm;
}
function TanggalIndo($date){
$BulanIndo = array("Januari", "Februari", "Maret", "April", "Mei", "Juni", "Juli", "Agustus", "September", "Oktober", "November", "Desember");
$tahun = substr($date, 0, 4);
$bulan = substr($date, 4, 2);
$tgl = substr($date, 6, 2);
$result =$tgl . " " . $BulanIndo[(int)$bulan-1] . " ". $tahun;
return($result);
}
function set_hari($tanggal){
$namahari = date('l', strtotime($tanggal));
if ($namahari == "Sunday") $namahari = "Minggu";
else if ($namahari == "Monday") $namahari = "Senin";
else if ($namahari == "Tuesday") $namahari = "Selasa";
else if ($namahari == "Wednesday") $namahari = "Rabu";
else if ($namahari == "Thursday") $namahari = "Kamis";
else if ($namahari == "Friday") $namahari = "Jumat";
else if ($namahari == "Saturday") $namahari = "Sabtu";
else $namahari = '';
return $namahari;
}
function getmahasiswa($wherex=''){
$KEDUA= $this->load->database('second', TRUE);
$KEDUA->select("*");
$KEDUA->from("vv_mahasiswa_profile2");
if($wherex !=''){
$KEDUA->where('nim',$wherex);
}
$q = $KEDUA->get();
$result = array();
if ($q->num_rows() > 0) {
$result = $q->result();
}
return $result;
}
function gridsyaratmk($nim,$idkurikulum,$thnmasuk){ ////untuk mengambil syarat matakuliah
$KEDUA= $this->load->database('second', TRUE);
$q = $KEDUA->query("SELECT v_syaratmk.kdmk
, v_syaratmk.nmmkind
, v_syaratmk.idsemester
, v_syaratmk.jmlsks
, v_syaratmk.nmlvlsyaratmk
, v_syaratmk.nilaihurufmin
, v_syaratmk.bobotnilaimin
, (SELECT accnilaihuruf
FROM
nilai
WHERE
kdmk = v_syaratmk.kdmk
AND nim = '$nim') AS nilaihurufmhs
, (SELECT accbobotnilai
FROM
nilai
WHERE
kdmk = v_syaratmk.kdmk
AND nim = '$nim') AS bobotnilaimhs
, (if((SELECT accbobotnilai
FROM
nilai
WHERE
kdmk = v_syaratmk.kdmk
AND nim = '$nim') > v_syaratmk.bobotnilaimin, 'Lulus Syarat', 'Tidak Lulus Syarat')) AS keterangan
FROM
v_syaratmk
WHERE
idkurikulum = '$idkurikulum' AND thnmasuk= '$thnmasuk'");
$makul='';
$a=1;
$data = array();
if ($q->num_rows() > 0) {
$data = $q->result();
}
foreach($data as $row) {
$makul .=$a.". ".($row->nmmkind)
." - Nilai (".(($row->nilaihurufmhs) ? $row->nilaihurufmhs:'-')." > ".(($row->nilaihurufmin) ? $row->nilaihurufmin:'-').") ".
($row->keterangan)."
";
$a= $a + 1;
}
return $makul;
}
function get_data_krs($nim,$kdprodi,$tahunmsk,$kdstsemester,$idkelas,$idsemester){
$KEDUA= $this->load->database('second', TRUE);
$querycek = $KEDUA->query("SELECT idsiskrs,kdsiskrs,nmsiskrs,idsemester FROM v_setkrs
WHERE kdprodi='".$kdprodi."'
AND idsemester IN (SELECT stmhssemester.idsemester FROM stmhssemester WHERE stmhssemester.nim='".$nim."' AND stmhssemester.kdstsemester='".$kdstsemester."')");
$idsiskrs = '';
$idsemesterx = '';
if ($querycek->num_rows() > 0) {
$rowcek = $querycek->row();
$idsiskrs = $rowcek->idsiskrs;
$idsemesterx = $rowcek->idsemester;
}
$query = $KEDUA->query("CALL sp_getKrsMatkul_cetak (?,?,?,?,?,?,?)",array($nim,$kdprodi,$kdstsemester,$tahunmsk,$idkelas,$idsemesterx,$idsiskrs));
$result = array();
if ($query->num_rows() > 0) {
$result = $query->result();
}
return $result;
}
function get_rows_krs($nim,$kdprodi,$tahunmsk,$kdstsemester,$idkelas,$idsemester,$isblanko){
// data table
$data = $this->get_data_krs($nim,$kdprodi,$tahunmsk,$kdstsemester,$idkelas,$idsemester);
$rows = "";
$no = 0;
$jmlsksambil = 0;
$jmlskssetuju = 0;
$no = 0;
$validkrs = (substr($kdstsemester,-1)==1) ? $this->nm_field2('nilai','setting','idset', 42):$this->nm_field2('nilai','setting','idset', 43);
foreach($data as $row)
{
// cek konversi
if($row->is_konversi == null){
if ($validkrs == 1) {
$syaratmk = ($this->gridsyaratmk($nim,$row->idkurikulum,$row->thnmasuk)) ? $this->gridsyaratmk($nim,$row->idkurikulum,$row->thnmasuk):'-';
} else {
$syaratmk = '-';
}
$ambil = ($row->ambilval) ? 'Ya':'Tidak';
$ambil = ($isblanko=='1') ? "":$ambil;
$namakelas = ($isblanko=='1') ? "":$row->namakelas;
$namaambil = ($isblanko=='1') ? "":$row->namaambil;
$namasetuju = ($isblanko=='1') ? "":$row->namasetuju;
if ($row->ambilval) { $jmlsksambil += $row->jmlsks; }
if ($row->idstkrs=='1') { $jmlskssetuju += $row->jmlsks; }
if ($isblanko=='1') {
$no++;
$rows .= "
".$no." |
".$row->kdmk." |
".$row->nmmkind." |
".$row->idsemester." |
".$row->jmlsks." |
".$syaratmk." |
".$ambil." |
".$namakelas." |
".$namaambil." |
".$namasetuju." |
";
} else {
if ($namaambil) {
$no++;
$rows .= "
".$no." |
".$row->kdmk." |
".$row->nmmkind." |
".$row->idsemester." |
".$row->jmlsks." |
".$syaratmk." |
".$ambil." |
".$namakelas." |
".$namaambil." |
".$namasetuju." |
";
}
}
}
}
$items['rows'] = $rows;
$items['jmlsksambil'] = $jmlsksambil;
$items['jmlskssetuju'] = $jmlskssetuju;
return $items;
}
function get_ip_before($nim,$idsemester){
$KEDUA= $this->load->database('second', TRUE);
$where = ($idsemester == '1') ? " AND idsemester = 1 ":" AND idsemester = $idsemester - 1 ";
$query = $KEDUA->query("SELECT sum(if((mutu IS NULL), 0, mutu)) / sum(jmlsks) AS ipk
FROM
v_nilai
WHERE
nim = $nim
AND nilaihuruf <> ''
$where
GROUP BY
nim");
$ipk = 0;
if ($query->row() > 0) {
$row = $query->row();
$ipk=$row->ipk;
}
return round($ipk,2);
}
function get_max_sks($ipbefore){
$KEDUA= $this->load->database('second', TRUE);
$query = $KEDUA->query("SELECT sksmax AS maxsks
FROM
bebanstudi
WHERE
$ipbefore
BETWEEN ipmin AND ipmax");
$maxsks = 0;
if ($query->row() > 0) {
$row = $query->row();
$maxsks=$row->maxsks;
}
return $maxsks;
}
function get_waktu_krs($nim,$kdstsemester){
$KEDUA= $this->load->database('second', TRUE);
$query = $KEDUA->query("SELECT tglkrs, jamkrs
FROM
krs
WHERE
nim = $nim
AND
kdstsemester = $kdstsemester
");
if ($query->row() > 0) {
$row = $query->row();
$tgl_krs = $this->TanggalIndo(date("Ymd", strtotime($row->tglkrs)));
$waktukrs = $tgl_krs." ".$row->jamkrs;
}
return $waktukrs;
}
function get_cetak_krs($nim,$kdprodi,$tahunmsk,$kdstsemester,$idkelas,$idsemester,$niduwali,$isblanko,$before=1,$between=5) {
$this->pdf_transkrip->SetCreator(PDF_CREATOR);
$this->pdf_transkrip->SetHeaderData(PDF_HEADER_LOGO, PDF_HEADER_LOGO_WIDTH,PDF_HEADER_TITLE,PDF_HEADER_STRING);
$this->pdf_transkrip->setPrintHeader(true);
$this->pdf_transkrip->setPrintFooter(false);
// set header and footer fonts
$this->pdf_transkrip->setHeaderFont(Array(PDF_FONT_NAME_MAIN, '', 10));
$this->pdf_transkrip->setFooterFont(Array(PDF_FONT_NAME_DATA, '', PDF_FONT_SIZE_DATA));
// set default monospaced font
$this->pdf_transkrip->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED);
// set margins
$this->pdf_transkrip->SetMargins('7', '40', '20');
$this->pdf_transkrip->SetHeaderMargin('20');
$this->pdf_transkrip->SetFooterMargin(PDF_MARGIN_FOOTER);
// set auto page breaks
$this->pdf_transkrip->SetAutoPageBreak(TRUE, '25');
// set image scale factor
$this->pdf_transkrip->setImageScale(PDF_IMAGE_SCALE_RATIO);
// set some language-dependent strings (optional)
// ---------------------------------------------------------
// set font
$this->pdf_transkrip->SetFont('helvetica', 'B', 10);
$this->pdf_transkrip->SetCellPadding(0);
// add a page
$this->pdf_transkrip->AddPage();
$this->pdf_transkrip->Write(0, '', '', 0, 'C', true, 0, false, false, 0);
$this->pdf_transkrip->Write(0, 'KARTU RENCANA STUDI', '', 0, 'C', true, 0, false, false, 0);
$this->pdf_transkrip->Write(0, '', '', 0, 'C', true, 0, false, false, 0);
$this->pdf_transkrip->SetFont('helvetica', '', 8);
$smstrakademik = $this->nm_field2('nmthnakademik','v_tahunakademik','kdstsemester', $kdstsemester);
$dosenwali = $this->nm_field2('nmdosdgngelar','dosen','nidu', $niduwali);
$tingkat = $this->nm_field2('tingkat','semester','idsemester', $idsemester);
$mhs = $this->getmahasiswa($nim);
$waktukrs = $this->get_waktu_krs($nim, $kdstsemester);
foreach($mhs as $item) {
$head = <<
Nomor Pokok Mahasiswa |
: $item->nim |
NIDU Dosen Wali |
: $niduwali |
Nama Mahasiswa |
: $item->nmmhs |
Nama Dosen Wali |
: $dosenwali |
Fakultas |
: $item->nmfakultas |
Tahun Akademik - Semester |
: $smstrakademik |
Program Studi |
: $item->nmprodi |
Semester / Tingkat |
: $idsemester / $tingkat |
Waktu Input KRS |
: $waktukrs |
|
|
EOD;
}
$this->pdf_transkrip->writeHTML($head,true,false,false,false);
$this->pdf_transkrip->SetFont('helvetica', '', 7);
$itemkrs = $this->get_rows_krs($nim,$kdprodi,$tahunmsk,$kdstsemester,$idkelas,$idsemester,$isblanko);
$datakrs = $itemkrs['rows'];
$jmlsksambil = ($isblanko=='1') ? "":$itemkrs['jmlsksambil'];
$jmlskssetuju = ($isblanko=='1') ? "":$itemkrs['jmlskssetuju'];
$ipbefore = $this->get_ip_before($nim,$idsemester);
$maxsks = $this->get_max_sks($ipbefore);
$maindata = <<
No. |
Kode MK |
Nama MK ( Matakuliah ) |
Semester |
SKS |
Syarat Matakuliah |
Ambil |
Kelas |
Keterangan |
Status |
$datakrs
Jumlah SKS yang diambil |
: $jmlsksambil |
|
|
Jumlah SKS yang disetujui |
: $jmlskssetuju |
|
|
IP Semester Sebelumnya |
: $ipbefore |
|
|
Jumlah Maksimal SKS yang diambil |
: $maxsks |
|
|
EOD;
$this->pdf_transkrip->writeHTML($maindata,true,false,false,false);
for($a=1;$a<$before;$a++){
$this->pdf_transkrip->Cell(60,4,'',0,1,'C');//space
}
$this->pdf_transkrip->Cell(70,4,'KSBA,',0,0,'C');
$this->pdf_transkrip->Cell(60,4,'',0,0,'C');
$this->pdf_transkrip->Cell(70,4,'DOSEN WALI,',0,1,'C');
for($a=0;$a<$between;$a++){
$this->pdf_transkrip->Cell(60,4,'',0,1,'C');//space
}
$this->pdf_transkrip->SetFont('helvetica', 'B', 8);
$this->pdf_transkrip->Cell(70,4,'______________________',0,0,'C');
$this->pdf_transkrip->Cell(60,4,'',0,0,'C');
$this->pdf_transkrip->SetFont('helvetica', 'B'.'U', 8);
$this->pdf_transkrip->Cell(70,4,$dosenwali,0,1,'C');
$this->pdf_transkrip->Output('krs-'.$nim.'-'.$kdstsemester.'.pdf', 'I');
}
}