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 nm_field2cond($column,$tbl,$whereb, $wherea, $whered, $wherec){
$KEDUA= $this->load->database('second', TRUE);
$q = "SELECT ".$column." as nm FROM ".$tbl." where ".$whereb." = '".$wherea."' AND ".$whered." = '".$wherec."'" ;
$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 getprodi($wherex=''){
$KEDUA= $this->load->database('second', TRUE);
$KEDUA->select("*");
$KEDUA->from("v_prodi");
if($wherex !=''){
$KEDUA->where('kdprodi',$wherex);
}
$q = $KEDUA->get();
$result = array();
if ($q->num_rows() > 0) {
$result = $q->result();
}
return $result;
}
function getvnilaiall($nim,$kdprodi,$tahunmsk,$limit,$start){
$KEDUA= $this->load->database('second', TRUE);
$q = $KEDUA->query("SELECT `nilai`.`kdprodi` AS `kdprodi`
, `nilai`.`kdmk` AS `kdmk`
, `matakuliah`.`nmmkind` AS `nmmkind`
, `matakuliah`.`nmmkeng` AS `nmmkeng`
, ifnull((SELECT max(`nilai`.`nilaihuruf`) AS `nilaihuruf`
FROM
`nilai`
WHERE
((`nilai`.`nim` = '".$nim."')
AND (`nilai`.`kdprodi` = `kurikulum`.`kdprodi`)
AND (`nilai`.`kdmk` = `kurikulum`.`kdmk`))), '-') AS `nilaihuruf`
, ifnull((SELECT max(`nilai`.`bobotnilai`) AS `bobotnilai`
FROM
`nilai`
WHERE
((`nilai`.`nim` = '".$nim."')
AND (`nilai`.`kdprodi` = `kurikulum`.`kdprodi`)
AND (`nilai`.`kdmk` = `kurikulum`.`kdmk`))), 0) AS `bobotnilai`
, `kurikulum`.`jmlsks` AS `jmlsks`
, ifnull(((SELECT max(`nilai`.`bobotnilai`) AS `bobotnilai`
FROM
`nilai`
WHERE
((`nilai`.`nim` = '".$nim."')
AND (`nilai`.`kdprodi` = `kurikulum`.`kdprodi`)
AND (`nilai`.`kdmk` = `kurikulum`.`kdmk`))) * `kurikulum`.`jmlsks`), 0) AS `mutu`
FROM
((`nilai`
JOIN `matakuliah`
ON (((`nilai`.`kdprodi` = `matakuliah`.`kdprodi`) AND (`nilai`.`kdmk` = `matakuliah`.`kdmk`))))
JOIN `kurikulum`
ON (((`kurikulum`.`kdprodi` = `nilai`.`kdprodi`) AND (`kurikulum`.`kdmk` = `nilai`.`kdmk`))))
WHERE
((`nilai`.`kdprodi` = '".$kdprodi."')
AND (`nilai`.`nim` = '".$nim."')
AND (`kurikulum`.thnmasuk ='".$tahunmsk."')
AND ((`nilai`.`idstsetuju` = '1')
OR isnull(`nilai`.`idstsetuju`)))
GROUP BY
`nilai`.`kdmk`
ORDER BY
`nilai`.`kdstsemester`
, `nilai`.`kdmk`
LIMIT
".$start.", ".$limit."");
$result = array();
if ($q->num_rows() > 0) {
$result = $q->result();
}
return $result;
}
function cekjumlahvnilaiall($nim,$kdprodi,$tahunmsk){
$KEDUA= $this->load->database('second', TRUE);
$q = $KEDUA->query("SELECT `nilai`.`kdprodi` AS `kdprodi`
, `nilai`.`kdmk` AS `kdmk`
, `matakuliah`.`nmmkind` AS `nmmkind`
, `matakuliah`.`nmmkeng` AS `nmmkeng`
, ifnull((SELECT max(`nilai`.`nilaihuruf`) AS `nilaihuruf`
FROM
`nilai`
WHERE
((`nilai`.`nim` = '".$nim."')
AND (`nilai`.`kdprodi` = `kurikulum`.`kdprodi`)
AND (`nilai`.`kdmk` = `kurikulum`.`kdmk`))), '-') AS `nilaihuruf`
, ifnull((SELECT max(`nilai`.`bobotnilai`) AS `bobotnilai`
FROM
`nilai`
WHERE
((`nilai`.`nim` = '".$nim."')
AND (`nilai`.`kdprodi` = `kurikulum`.`kdprodi`)
AND (`nilai`.`kdmk` = `kurikulum`.`kdmk`))), 0) AS `bobotnilai`
, `kurikulum`.`jmlsks` AS `jmlsks`
, ifnull(((SELECT max(`nilai`.`bobotnilai`) AS `bobotnilai`
FROM
`nilai`
WHERE
((`nilai`.`nim` = '".$nim."')
AND (`nilai`.`kdprodi` = `kurikulum`.`kdprodi`)
AND (`nilai`.`kdmk` = `kurikulum`.`kdmk`))) * `kurikulum`.`jmlsks`), 0) AS `mutu`
FROM
((`nilai`
JOIN `matakuliah`
ON (((`nilai`.`kdprodi` = `matakuliah`.`kdprodi`) AND (`nilai`.`kdmk` = `matakuliah`.`kdmk`))))
JOIN `kurikulum`
ON (((`kurikulum`.`kdprodi` = `nilai`.`kdprodi`) AND (`kurikulum`.`kdmk` = `nilai`.`kdmk`))))
WHERE
((`nilai`.`kdprodi` = '".$kdprodi."')
AND (`nilai`.`nim` = '".$nim."')
AND (`kurikulum`.thnmasuk ='".$tahunmsk."')
AND ((`nilai`.`idstsetuju` = '1')
OR isnull(`nilai`.`idstsetuju`)))
GROUP BY
`nilai`.`kdmk`
ORDER BY
`nilai`.`kdstsemester`
, `nilai`.`kdmk`");
$result = 0;
if ($q->num_rows() > 0) {
$result = $q->num_rows();
} else {
$result = 0;
}
return $result;
}
function get_rows($nim,$kdprodi,$tahunmsk){
$numrows = $this->cekjumlahvnilaiall($nim,$kdprodi,$tahunmsk); // jumlah baris
$batas = 35; // batas record per tabel
$jmlsks = 0;
$jmlskskali = 0;
$jmlmutu = 0;
$nh = array("A", "B", "C", "D", "E");
if ($numrows <= $batas) {
$nilai = $this->getvnilaiall($nim,$kdprodi,$tahunmsk,$batas,0);
$tr = "";
$no=0;
foreach($nilai as $item) {
$no++;
$tr .= "
$no |
$item->nmmkind |
$item->nilaihuruf |
".intval($item->bobotnilai)." |
$item->jmlsks |
".intval($item->mutu)." |
";
$jmlsks = $jmlsks + $item->jmlsks;
if ($item->nilaihuruf != "-") {//if (in_array($item->nilaihuruf, $nh)) {
$jmlskskali = $jmlskskali + $item->jmlsks;
$jmlmutu = $jmlmutu + intval($item->mutu);
}
}
$tbl['data'] = "
|
No. |
Mata Kuliah |
HM |
AM |
sks |
M |
$tr
|
";
} else {
$nilai1 = $this->getvnilaiall($nim,$kdprodi,$tahunmsk,$batas,0);
$nilai2 = $this->getvnilaiall($nim,$kdprodi,$tahunmsk,$batas,$batas);
$tr1 = "";
$tr2 = "";
$no=0;
foreach($nilai1 as $item) {
$no++;
$tr1 .= "
$no |
$item->nmmkind |
$item->nilaihuruf |
".intval($item->bobotnilai)." |
$item->jmlsks |
".intval($item->mutu)." |
";
$jmlsks = $jmlsks + $item->jmlsks;
if ($item->nilaihuruf != "-") {//if (in_array($item->nilaihuruf, $nh)) {
$jmlskskali = $jmlskskali + $item->jmlsks;
$jmlmutu = $jmlmutu + intval($item->mutu);
}
}
$no=35;
foreach($nilai2 as $item) {
$no++;
$tr2 .= "
$no |
$item->nmmkind |
$item->nilaihuruf |
".intval($item->bobotnilai)." |
$item->jmlsks |
".intval($item->mutu)." |
";
$jmlsks = $jmlsks + $item->jmlsks;
if (in_array($item->nilaihuruf, $nh)) {
$jmlskskali = $jmlskskali + $item->jmlsks;
$jmlmutu = $jmlmutu + intval($item->mutu);
}
}
$tbl['data'] = "
No. |
Mata Kuliah |
HM |
AM |
sks |
M |
$tr1
|
No. |
Mata Kuliah |
HM |
AM |
sks |
M |
$tr2
|
";
}
$tbl['data'] .= "
Keterangan: HM: Huruf Mutu, AM: Angka Mutu, sks: satuan kredit semester, M: HM x AM.
";
$tbl['sks'] = $jmlsks;
$tbl['ipk'] = $jmlmutu/$jmlskskali;
return $tbl;
}
function get_transkrip($nim,$kdprodi,$tahunmsk,$tglcetak) {
$prodinya = $this->getprodi($kdprodi);
foreach($prodinya as $itemprodi){
if ($itemprodi->nmstakreditasi) {
$akreditasi = strtoupper('Terakreditasi, ').'"'.$itemprodi->kdstakreditasi.'"';
$nosk = 'No. '.$itemprodi->noskakreditasi;
$tglsk = 'Tanggal '.$this->TanggalIndo(date("Ymd",strtotime($itemprodi->tglskakreditasi)));
} else {
$akreditasi = '-';
$nosk = '';
$tglsk = '';
}
}
$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(false);
$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('10');
$this->pdf_transkrip->SetFooterMargin(PDF_MARGIN_FOOTER);
// set auto page breaks
$this->pdf_transkrip->SetAutoPageBreak(TRUE, '10');
// 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', 11);
$this->pdf_transkrip->SetCellPadding(0);
// add a page
$this->pdf_transkrip->AddPage();
$mhs = $this->getmahasiswa($nim);
foreach($mhs as $item) {
$this->pdf_transkrip->Write(0, 'TRANSKRIP AKADEMIK', '', 0, 'C', true, 0, false, false, 0);
$this->pdf_transkrip->SetFont('helvetica', '', 9);
$this->pdf_transkrip->Write(0, 'Nomor: '.$item->notranskrip, '', 0, 'C', true, 0, false, false, 0);
$this->pdf_transkrip->SetFont('helvetica', '', 11);
$this->pdf_transkrip->Write(0, 'Nama Mahasiswa: '.$item->nmmhs, '', 0, 'C', true, 0, false, false, 0);
$this->pdf_transkrip->SetFont('helvetica', '', 9);
$skripsi=$item->jdlskripsiind;
$tgllhr = $this->TanggalIndo(date("Ymd",strtotime($item->tgllahir)));
$pimpin1=$this->nm_field2('nmpimpinan', 'pimpinan', 'jabatan','1');
$pimpin1gelar=$this->nm_field2('gelar', 'pimpinan', 'jabatan','1');
$pimpin2=$this->nm_field2cond('nmpimpinan', 'pimpinan', 'jabatan','5', 'kdfakultas',$item->kdfakultas);
$head = <<
Nomor Pokok Mahasiswa |
: $item->nim |
Fakultas |
: $item->nmfakultas |
Tempat, tanggal lahir |
: $item->tptlahir, $tgllhr |
Program Studi |
: $item->nmprodi |
Tahun Masuk |
: $item->thnmasuk |
Status Program Studi |
: $akreditasi |
Status Awal Mahasiswa |
: $item->nmstawalmhs |
|
$nosk |
Jenjang Pendidikan |
: $item->nmjenjangstudi |
|
$tglsk |
EOD;
}
$this->pdf_transkrip->writeHTML($head,true,false,false,false);
$rows_mhs = $this->get_rows($nim,$kdprodi,$tahunmsk);
$this->pdf_transkrip->writeHTML($rows_mhs['data'],true,false,false,false);
$jmlsksall = $rows_mhs['sks'];
$ipkall = round($rows_mhs['ipk'],2);
$yudisium = $this->squery("select * from setipk where '".$ipkall."' between ipkdari and ipksampai");
if ($yudisium) {
$yudisium = $yudisium->keterangan;
} else {
$yudisium = null;
}
$foot = <<
Jumlah sks |
: $jmlsksall |
Judul Tugas Akhir : |
IPK |
: $ipkall |
$skripsi |
Yudisium |
: $yudisium |
EOD;
$this->pdf_transkrip->writeHTML($foot,true,false,false,false);
$photo = "
Dekan,
".$pimpin2."
|
|
Bandung, ".$this->TanggalIndo(date("Ymd",strtotime($tglcetak)))."
Rektor,
".$pimpin1."
".$pimpin1gelar."
|
";
$this->pdf_transkrip->writeHTML($photo,true,false,false,false);
$this->pdf_transkrip->Output('transkrip'.$nim.'.pdf', 'I');
}
}