to('auth'); } } public function graph_matoa() { // $opsiWilZona = $this->request->getPost('opsiWilZona') ?? null; $Ald = new AldLibrary(); $username = session('nip'); $opsiWilZona = $Ald->decryptMe($this->request->getPost('opsiWilZona'), $username) ?? null; if (!in_array($opsiWilZona, ['wilayah', 'zona', ''])) { $dataReturn['poi_agg'] = []; $dataReturn['kpdl_agg'] = []; } else { $dataReturn['poi_agg'] = $this->get_poi_agg(); $dataReturn['kpdl_agg'] = $this->get_kpdl_agg(); } return json_encode($dataReturn); } public function sebaranPembayaran() { $ret = []; $tahun = $this->request->getPost('tahun') ?? date('Y'); $bulan = $this->request->getPost('bulan') ?? date('m'); $sebaranPembayaran = new Pembayaran; $dataReturn['dataC'] = $sebaranPembayaran->dataC($this->request, $tahun, $bulan); $dataReturn['dataMin1'] = $sebaranPembayaran->dataC($this->request, $tahun, $bulan - 1); $dataReturn['dataMin2'] = $sebaranPembayaran->dataC($this->request, $tahun, $bulan - 2); return $this->respond($dataReturn, 200); // return json_encode($dataReturn); } public function sebaranIdentifikasi() { $ret = []; $sebaran = new Identifikasi; $dataReturn['data'] = $sebaran->data($this->request); return $this->respond($dataReturn, 200); // return json_encode($dataReturn); } public function sebaranPayComp() { $tahun = $this->request->getPost('tahun') ?? date('Y'); $bulan = $this->request->getPost('bulan') ?? date('m'); $sebaran = new PayComp; $dataReturn['dataC'] = $sebaran->dataC($this->request, $tahun, $bulan); $dataReturn['dataMin1'] = $sebaran->dataC($this->request, $tahun, $bulan - 1); $dataReturn['dataMin2'] = $sebaran->dataC($this->request, $tahun, $bulan - 2); return $this->respond($dataReturn, 200); } public function sebaranSof() { $tahun = $this->request->getPost('tahun') ?? date('Y'); $bulan = $this->request->getPost('bulan') ?? date('m'); $sebaran = new Sof; $dataReturn['data'] = $sebaran->dataC($this->request, $tahun, $bulan); return $this->respond($dataReturn, 200); } public function sebaranJenisStatusWp() { $sebaran = new JenisStatus; $dataReturn['dataJenis'] = $sebaran->data($this->request, 'jenis'); $dataReturn['dataStatus'] = $sebaran->data($this->request, 'status'); return $this->respond($dataReturn, 200); } public function sebaranPengampu() { ini_set('max_input_vars', 3000); $sebaran = new Pengampu; $dataReturn['assign'] = $sebaran->data($this->request, 'assign'); $dataReturn['unassign'] = $sebaran->data($this->request, 'unassign'); return $this->respond($dataReturn, 200); } public function sebaranSPTTahunan() { $sebaran = new SPTTAhunan; $tahun = $this->request->getGet('tahun') ?? date('Y'); $dataReturn['data'] = $sebaran->data($this->request, $tahun); return $this->respond($dataReturn, 200); } public function sebaranKLU() { $sebaran = new KLU; $tahun = $this->request->getGet('tahun') ?? date('Y'); $dataReturn['dataKluTerdaftar'] = $sebaran->data($this->request, 'dataKluTerdaftar'); $dataReturn['dataKluYgBayar'] = $sebaran->data($this->request, 'dataKluYgBayar'); $dataReturn['dataRupiahBayar'] = $sebaran->data($this->request, 'dataRupiahBayar'); return $this->respond($dataReturn, 200); } public function identifikasiLapangan() { $Ald = new AldLibrary(); $username = session('nip'); $sebaran = new IdentifikasiLapangan; $bulan = $Ald->decryptMe($this->request->getPost('bulan'), $username) ?? 'semua'; $dataReturn['kpdl'] = $sebaran->dataKpdl($this->request, $bulan); $dataReturn['categories'] = ["Jan", "Feb", "Mar", "Apr", "Mei", "Jun", "Jul", "Agu", "Sep", "Okt", "Nov", "Des"]; if ($bulan == 'semua') { $dataReturn['categories'] = ["Jan", "Feb", "Mar", "Apr", "Mei", "Jun", "Jul", "Agu", "Sep", "Okt", "Nov", "Des"]; } else { $dataReturn['categories'] = $sebaran->generateSeries($bulan); } $arr_data_akum_dikenali = array(); $nilai_akum = 0; foreach ($dataReturn['kpdl'] as $data) { $nilai_akum += $data; array_push($arr_data_akum_dikenali, $nilai_akum); } $c_arr = count($arr_data_akum_dikenali) - 1; $arr_data_akum_dikenali_temp = $arr_data_akum_dikenali; for ($i = $c_arr; $i > 0; $i--) { if ($arr_data_akum_dikenali[$i] == $arr_data_akum_dikenali[$i - 1]) { $arr_data_akum_dikenali_temp[$i] = 0; } else { break; } } $dataReturn['akum'] = $arr_data_akum_dikenali_temp; return $this->respond($dataReturn, 200); } public function getBulan() { $Ald = new AldLibrary(); $username = session('nip'); $bulan = ['semua', 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]; $bulanEnc = []; foreach ($bulan as $key => $value) { $bulanEnc[] = [ 'label' => $value, 'value' => $Ald->encryptMe($value, $username), ]; } return $this->respond($bulanEnc, 200); } private function get_poi_agg() { ini_set('max_input_vars', 3000); $Ald = new AldLibrary(); $username = session('nip'); $opsiWilZona = $Ald->decryptMe($this->request->getPost('opsiWilZona'), $username) ?? null; $adm4_pcode = []; foreach ($this->request->getPost('adm4_pcode') ?? [] as $key => $value) { array_push($adm4_pcode, $Ald->decryptKpdl($value, $username)); } $id_poly_zona = []; foreach ($this->request->getPost('id_poly_zona') ?? [] as $key => $value) { array_push($id_poly_zona, $Ald->decryptKpdl($value, $username)); } $db = \Config\Database::connect(); $sqlGenerate = $db->table("KPDL_MV_JML_POI_AGG") ->select("BULAN, sum(JML) as JML") ->where('TAHUN =', date('Y')) ->where('BULAN <=', (int) date('m')) ->groupBy('BULAN'); if ($opsiWilZona == 'wilayah') { $sqlGenerate->whereIn('ADM4_PCODE', $adm4_pcode); } if ($opsiWilZona == 'zona') { $sqlGenerate->whereIn('ID_POLY_ZONA', $id_poly_zona); } $sqlGenerate = $sqlGenerate->getCompiledSelect(); $data = $db->table("BULAN a") ->select("KODE as BULAN, JML") ->join("(" . $sqlGenerate . ") b", "KODE = BULAN", 'left', false) ->orderBy("BULAN", 'asc', false)->get()->getResult(); $dataPoiAgg = $this->single_array($data, 'JML'); return $dataPoiAgg; } private function get_kpdl_agg() { $Ald = new AldLibrary(); $username = session('nip'); $opsiWilZona = $Ald->decryptMe($this->request->getPost('opsiWilZona'), $username) ?? null; $adm4_pcode = []; foreach ($this->request->getPost('adm4_pcode') ?? [] as $key => $value) { array_push($adm4_pcode, $Ald->decryptKpdl($value, $username)); } $id_poly_zona = []; foreach ($this->request->getPost('id_poly_zona') ?? [] as $key => $value) { array_push($id_poly_zona, $Ald->decryptKpdl($value, $username)); } $db = \Config\Database::connect(); $sqlGenerate = $db->table("KPDL_MV_JML_KPDL_AGG") ->select("BULAN, sum(JML) as JML") ->where('TAHUN =', date('Y')) ->where('BULAN <=', (int) date('m')) ->groupBy('BULAN'); if ($opsiWilZona == 'wilayah') { $sqlGenerate->whereIn('ADM4_PCODE', $adm4_pcode); } if ($opsiWilZona == 'zona') { $sqlGenerate->whereIn('ID_POLY_ZONA', $id_poly_zona); } $sqlGenerate = $sqlGenerate->getCompiledSelect(); $data = $db->table("BULAN a") ->select("KODE as BULAN, JML") ->join("(" . $sqlGenerate . ") b", "KODE = BULAN", 'left', false) ->orderBy("BULAN", 'asc', false)->get()->getResult(); $dataPoiAgg = $this->single_array($data, 'JML'); return $dataPoiAgg; } private function single_array($a, $key) { $ret = []; foreach ($a as $b) { array_push($ret, floatval($b->$key)); } for ($i = 0; $i < 12; $i++) { if (!isset($ret[$i])) { array_push($ret, 0); } } return $ret; } }