Files
simutu/app/undtu/excel.php
2025-10-09 12:30:11 +07:00

142 lines
5.9 KiB
PHP

<?php
require_once '../../assets/excel/PHPExcel.php';
// koneksi ke database
include('../koneksi.php');
$a=$_GET['a'];
$b=$_GET['b'];
$bln2=$_GET['bln2'];
$thn2=$_GET['thn2'];
if ($a=='Acara') {
$r1=strtolower($b);
//$bln2='';
//$thn2='';
} else
if ($a=='Penanggung Jawab') {
$p1=strtolower($b);
//$bln2='';
//$thn2='';
} else
if ($a=='Nomor Undangan') {
$s1=strtolower($b);
//$bln2='';
//$thn2='';
} else
if ($a=='Status') {
$t1=strtolower($b);
//$bln2='';
//$thn2='';
} else {
//$bln2=$_GET['bln2'];
//$thn2=$_GET['thn2'];
}
$objPHPExcel = new PHPExcel();
$objPHPExcel->getDefaultStyle()->getFont()->setName('Arial');
$objPHPExcel->getDefaultStyle()->getFont()->setSize(10);
$objPHPExcel->getDefaultStyle()->getAlignment()->setWrapText(true);
//$objPHPExcel->getDefaultStyle()->getNumberFormat()->setFormatCode('@');
$objPHPExcel->getSheet(0)->getColumnDimension('A')->setWidth(5);
$objPHPExcel->getSheet(0)->getColumnDimension('B')->setWidth(25);
$objPHPExcel->getSheet(0)->getColumnDimension('C')->setWidth(20);
$objPHPExcel->getSheet(0)->getColumnDimension('D')->setWidth(55);
$objPHPExcel->getSheet(0)->getColumnDimension('E')->setWidth(37);
$objPHPExcel->getSheet(0)->getColumnDimension('F')->setWidth(12);
$objPHPExcel->getSheet(0)->getColumnDimension('G')->setWidth(24);
$objPHPExcel->getSheet(0)->getColumnDimension('H')->setWidth(18);
$styleBold = array('font' => array('bold' => true));
$objPHPExcel->getSheet(0)->getStyle('A1:H1')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
$objPHPExcel->getSheet(0)->getStyle('A1:H1')->applyFromArray($styleBold);
$objPHPExcel->getSheet(0)->getRowDimension('1')->setRowHeight(30);
$objPHPExcel->getSheet(0)->setTitle('LAPORAN KEGIATAN RAPAT');
$objPHPExcel->getSheet(0)
->setCellValue('A1', 'No')
->setCellValue('B1', 'Ruangan')
->setCellValue('C1', 'Tgl Acara')
->setCellValue('D1', 'Acara')
->setCellValue('E1', 'Penanggung Jawab')
->setCellValue('F1', 'Status')
->setCellValue('G1', 'No Undangan')
->setCellValue('H1', 'Kirim');
$query = "SELECT (SELECT r.nama FROM data_ruangan r WHERE r.id=k.tempat),
k.tgl_acara,k.waktu_mulai,k.waktu_selesai,k.tujuan,k.st_persiapan,
k.no_undangan,k.id,
(SELECT s.nama FROM satuan_kerja s WHERE s.id=k.penanggungjawab),
k.st_batal,p.tanggal_kirim,COUNT(l.file)
FROM riwayat_kegiatan k
LEFT OUTER JOIN kirim_permintaan p ON (k.id=p.riwayat_kegiatan_id)
LEFT OUTER JOIN lampiran l ON (k.id=l.riwayat_kegiatan_id)
WHERE
k.st_persiapan IN ('Pending','Ready')
".($thn2 == '' ? "" : "AND EXTRACT(YEAR FROM DATE(k.tgl_acara))='$thn2'")."
".($bln2 == '' ? "" : "AND EXTRACT(MONTH FROM DATE(k.tgl_acara))='$bln2'")."
".($r1 == null ? "" : "AND lower(k.tujuan) LIKE '%$r1%'")."
".($p1 == null ? "" : "AND lower((SELECT s.nama FROM satuan_kerja s WHERE s.id=k.penanggungjawab)) LIKE '%$p1%'")."
".($s1 == null ? "" : "AND lower(k.no_undangan) LIKE '%$s1%'")."
".($t1 == null ? "" : "AND lower(k.st_persiapan)='$t1' AND k.st_batal IS NULL")."
GROUP BY
(SELECT r.nama FROM data_ruangan r WHERE r.id=k.tempat),
k.tgl_acara,k.waktu_mulai,k.waktu_selesai,k.tujuan,k.st_persiapan,
k.no_undangan,k.id,
(SELECT s.nama FROM satuan_kerja s WHERE s.id=k.penanggungjawab),
k.st_batal,p.tanggal_kirim
ORDER BY k.tgl_acara DESC";
$hasil = pg_query($query);
$baris = 2;
$a=1;
while ($row = pg_fetch_array($hasil))
{
$ruangan=$row[0];
$tgl_acara=date('d-m-Y',strtotime($row['tgl_acara']));
$waktu=date('H:i',strtotime($row['waktu_mulai'])).' - '.date('H:i',strtotime($row['waktu_selesai']));
$acara=$row['tujuan'];
$penanggungjawab=$row[8];
if (($row['no_undangan']!=null) && ($row['st_persiapan']=='Pending')) {$status='Siap kirim';} else {$status=$row['st_persiapan'];}
if ($row['no_undangan']==NULL) {
$no_undangan='';
} else {
$no_undangan='005 / '.$row['no_undangan'].' / 102.7 / '.date('Y',strtotime($row['tgl_acara']));
}
if ($row['tanggal_kirim']) {$tanggal_kirim=date('d-m-Y H:i',strtotime($row['tanggal_kirim']));}
$objPHPExcel->getSheet(0)
->setCellValue('A'.$baris, $a)
->setCellValue('B'.$baris, $ruangan)
->setCellValue('C'.$baris, $tgl_acara."\n".$waktu)
->setCellValue('D'.$baris, $acara)
->setCellValue('E'.$baris, $penanggungjawab)
->setCellValue('G'.$baris, $no_undangan)
->setCellValue('F'.$baris, $status)
->setCellValue('H'.$baris, $tanggal_kirim);
$objPHPExcel->getSheet(0)->getStyle('A1:A'.$baris)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
$objPHPExcel->getSheet(0)->getStyle('F1:H'.$baris)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
$objPHPExcel->getSheet(0)->getStyle('A1:J'.$baris)->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);
$a++;
$baris++;
}
$akhir=$baris-1;
$objPHPExcel->setActiveSheetIndex(0);
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="laporan_kegiatan_rapat.xls"');
header('Cache-Control: max-age=0');
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output');
exit;
?>