first commit

This commit is contained in:
Kicap Karan
2022-10-29 04:16:53 +08:00
parent 369e9b7829
commit 522ee5201d
18 changed files with 1411 additions and 3272 deletions

1
.gitignore vendored
View File

@ -15,6 +15,7 @@ user_guide_src/cilexer/build/*
user_guide_src/cilexer/dist/*
user_guide_src/cilexer/pycilexer.egg-info/*
/vendor/
/user_guide/
# IDE Files
#-------------------------

View File

@ -78,7 +78,7 @@ $db['default'] = array(
'hostname' => 'localhost',
'username' => 'root',
'password' => '',
'database' => 'absensi_karyawan',
'database' => 'db_topsis',
'dbdriver' => 'mysqli',
'dbprefix' => '',
'pconnect' => FALSE,

View File

@ -16,24 +16,24 @@ class Admin extends CI_Controller
$this->session->unset_userdata(array('nik', 'level'));
redirect('/login');
} else {
$cek_data = $this->model->tampil_data_where('tb_admin', array('nik' => $this->session->userdata('nik')))->result();
// $cek_data = $this->model->tampil_data_where('tb_admin', array('nik' => $this->session->userdata('nik')))->result();
if (count($cek_data) > 0) {
# code...
$this->main['level'] = $cek_data[0]->level;
$this->main["nama"] = $cek_data[0]->nama;
$cek_data_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $cek_data[0]->id_dinas])->result()[0];
$this->main["id_dinas"] = $cek_data_dinas->id_dinas;
$this->main["dinas"] = $cek_data_dinas->dinas;
$this->main['lat'] = $cek_data_dinas->lat;
$this->main['lng'] = $cek_data_dinas->lng;
$this->main['radius'] = $cek_data_dinas->radius;
$this->month = date("m");
$this->year = date("Y");
} else {
$this->session->unset_userdata(array('nik', 'level'));
redirect('/login');
}
// if (count($cek_data) > 0) {
// # code...
// $this->main['level'] = $cek_data[0]->level;
// $this->main["nama"] = $cek_data[0]->nama;
// $cek_data_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $cek_data[0]->id_dinas])->result()[0];
// $this->main["id_dinas"] = $cek_data_dinas->id_dinas;
// $this->main["dinas"] = $cek_data_dinas->dinas;
// $this->main['lat'] = $cek_data_dinas->lat;
// $this->main['lng'] = $cek_data_dinas->lng;
// $this->main['radius'] = $cek_data_dinas->radius;
// $this->month = date("m");
// $this->year = date("Y");
// } else {
// $this->session->unset_userdata(array('nik', 'level'));
// redirect('/login');
// }
}
}
@ -41,322 +41,101 @@ class Admin extends CI_Controller
function index()
{
$main = $this->main;
$main["header"] = "Halaman Utama";
$main['list_karyawan'] = $this->model->tampil_data_where('tb_karyawan', ['id_dinas' => $main['id_dinas']])->result();
$array = $main['list_karyawan'];
$today = date("Y-m-d");
foreach ($array as $key => $value) {
$main['list_karyawan'][$key]->status_kerja = '-';
$check_libur = $this->model->tampil_data_where('tb_informasi_libur', ['nik' => $value->nik, 'tanggal' => $today])->result();
if (count($check_libur) > 0) {
$main['list_karyawan'][$key]->status_kerja = 'Libur';
}
$check_perjalanan_dinas = $this->model->tampil_data_where('tb_informasi_perjalanan_dinas', ['nik' => $value->nik, 'tanggal' => $today])->result();
if (count($check_perjalanan_dinas) > 0) {
$main['list_karyawan'][$key]->status_kerja = 'Perjalanan Dinas';
}
}
// echo $this->level;
$this->load->view('admin/menu/index', $main);
// $this->load->view('admin/index');
// echo "sini index admin";
}
function pengaturan()
{
$main = $this->main;
$main["header"] = "Halaman Pengaturan Lokasi Dinas";
// echo $this->level;
$this->load->view('admin/menu/pengaturan', $main);
// $this->load->view('admin/index');
// echo "sini index admin";
}
function karyawan()
{
if ($this->input->post('proses') == "table_karyawan") {
$list = $this->m_tabel_ss->get_datatables(array('nik', 'nama', 'no_telpon', 'jabatan', 'pangkat'), array(null, 'nik', 'nama', 'no_telpon', 'jabatan', 'pangkat', null), array('status' => 'desc'), "tb_karyawan", null, array("id_dinas" => $this->main['id_dinas']), "*");
if ($this->input->post('proses') == "table_penduduk") {
$list = $this->m_tabel_ss->get_datatables(array('nik', 'nama', 'no_hp', 'jenis_kelamin'), array('nik', 'nama', null, 'jenis_kelamin', null), array('status' => 'desc'), "tb_penduduk", null, null, "*");
$data = array();
$no = $_POST['start'];
foreach ($list as $field) {
$stat = '';
$title = 'Tukar ID Smartphone';
if ($field->device_id == null || $field->device_id == '') {
$stat = 'disabled';
$title = 'Karyawan Belum Login Dari Smartphone';
}
// get umur
$date1 = new DateTime($field->tgl_lahir);
$date2 = new DateTime("now");
$interval = $date1->diff($date2);
$umur = $interval->y;
$no++;
$row = array();
$row[] = $no;
// $row[] = $no;
$row[] = $field->nik;
$row[] = $field->nama;
$row[] = $field->no_telpon;
$row[] = $field->jabatan;
$row[] = $field->pangkat;
$row[] = "<center><button type='button' onclick='karyawan_edit(" . '"' . (string)$field->nik . '"' . ")' title='Edit Detail Karyawan' class='btn btn-primary btn-circle btn-sm waves-effect waves-light'><i class='ico fa fa-edit'></i></button> &nbsp <button type='button' onclick='tukar_id(" . '"' . (string)$field->nik . '"' . ")' title='" . $title . "' " . $stat . " class='btn btn-warning btn-circle btn-sm waves-effect waves-light'><i class='ico zmdi zmdi-smartphone-landscape-lock'></i></button> &nbsp <button type='button' onclick='hapus_karyawan(" . '"' . (string)$field->nik . '"' . ")' title='Hapus Karyawan' class='btn btn-danger btn-circle btn-sm waves-effect waves-light'><i class='ico zmdi zmdi-delete'></i></button></center>";
$row[] = $umur;
$row[] = $field->no_hp;
$row[] = $field->jenis_kelamin;
$row[] = "<center><button type='button' onclick='edit_penduduk(" . '"' . (string)$field->nik . '"' . ")' title='Edit Detail Penduduk' class='btn btn-primary btn-circle btn-sm waves-effect waves-light'><i class='ico fa fa-edit'></i></button> &nbsp <button type='button' onclick='hapus_penduduk(" . '"' . (string)$field->nik . '"' . ")' title='Hapus Penduduk' class='btn btn-danger btn-circle btn-sm waves-effect waves-light'><i class='ico zmdi zmdi-delete'></i></button></center>";
$data[] = $row;
}
$output = array(
"draw" => $_POST['draw'],
"recordsTotal" => $this->m_tabel_ss->count_all("tb_karyawan", null, array("id_dinas" => $this->main['id_dinas']), "*"),
"recordsFiltered" => $this->m_tabel_ss->count_filtered(array('nik', 'nama', 'no_telpon', 'jabatan', 'pangkat'), array(null, 'nik', 'nama', 'no_telpon', 'jabatan', 'pangkat', null), array('status' => 'desc'), "tb_karyawan", null, array("id_dinas" => $this->main['id_dinas']), "*"),
"recordsTotal" => $this->m_tabel_ss->count_all("tb_penduduk", null, null, "*"),
"recordsFiltered" => $this->m_tabel_ss->count_filtered(array('nik', 'nama', 'no_hp', 'jenis_kelamin'), array('nik', 'nama', null, 'jenis_kelamin', null), array('status' => 'desc'), "tb_penduduk", null, null, "*"),
"data" => $data,
);
//output dalam format JSON
echo json_encode($output);
} else {
$main = $this->main;
$main["header"] = "Halaman Karyawan";
$this->load->view('admin/menu/karyawan', $main);
$main["header"] = "Halaman Utama";
$this->load->view('admin/menu/index', $main);
}
}
function jam_kerja()
function topsis($nik = null)
{
$main = $this->main;
$main["header"] = "Halaman Jam Kerja";
// echo $this->level;
$this->load->view('admin/menu/jam_kerja', $main);
}
function libur()
{
if ($this->input->post('proses') == "table_libur") {
$list = $this->m_tabel_ss->get_datatables(array('range_tanggal', 'created_at'), array(null, 'range_tanggal', null, 'created_at', null), array('id_libur' => 'desc'), "tb_libur", null, array("id_dinas" => $this->main['id_dinas']), "*");
if ($this->input->post('proses') == "table_penduduk") {
$list = $this->m_tabel_ss->get_datatables(array('nik', 'nama'), array('nik', 'nama', null, null), array('status' => 'desc'), "tb_penduduk", null, null, "*");
$data = array();
$no = $_POST['start'];
foreach ($list as $field) {
$list_karyawan = json_decode($field->list_karyawan);
$cek_data_bantuan = $this->model->tampil_data_where('tb_detail', array('nik' => $field->nik))->result();
$value_karyawan = '';
foreach ($list_karyawan as $key => $value) {
$check_karyawan = $this->model->tampil_data_where('tb_karyawan', ['nik' => $value])->result();
$value_karyawan .= " " . $check_karyawan[0]->nama . ' ,';
if (count($cek_data_bantuan) > 0) {
$status = $cek_data_bantuan[0]->status == '' ? 'Belum Diverifikasi' : $cek_data_bantuan[0]->status;
} else {
$status = "Data Belum Dimasukkan";
}
$value_karyawan = rtrim($value_karyawan, ",");
$no++;
$row = array();
$row[] = $no;
$row[] = $field->range_tanggal;
$row[] = $value_karyawan;
$row[] = $field->created_at;
$row[] = "<center><button type='button' onclick='check_info(" . '"' . (string)$field->id_libur . '"' . ")' title='Check Informasi Libur' class='btn btn-primary btn-circle btn-sm waves-effect waves-light'><i class='ico zmdi zmdi-info-outline'></i></button></center>";
// $row[] = $no;
$row[] = $field->nik;
$row[] = $field->nama;
$row[] = $status;
$row[] = "<center><button type='button' onclick='status_bantuan(" . '"' . (string)$field->nik . '"' . ")' title='Lihat Status Bantuan Sosial' class='btn btn-primary btn-circle btn-sm waves-effect waves-light'><i class='ico fa fa-edit'></i></button></center>";
$data[] = $row;
}
$output = array(
"draw" => $_POST['draw'],
"recordsTotal" => $this->m_tabel_ss->count_all("tb_libur", null, array("id_dinas" => $this->main['id_dinas']), "*"),
"recordsFiltered" => $this->m_tabel_ss->count_filtered(array('range_tanggal', 'created_at'), array(null, 'range_tanggal', null, 'created_at', null), array('id_libur' => 'desc'), "tb_libur", null, array("id_dinas" => $this->main['id_dinas']), "*"),
"recordsTotal" => $this->m_tabel_ss->count_all("tb_penduduk", null, null, "*"),
"recordsFiltered" => $this->m_tabel_ss->count_filtered(array('nik', 'nama'), array('nik', 'nama', null, null), array('status' => 'desc'), "tb_penduduk", null, null, "*"),
"data" => $data,
);
//output dalam format JSON
echo json_encode($output);
} else {
$main = $this->main;
$main["header"] = "Halaman Pengaturan Libur";
}
elseif($nik != null){
$cek_data = $this->model->tampil_data_where('tb_penduduk', array('nik' => $nik))->result();
if(count($cek_data) > 0){
// cek umur
$date1 = new DateTime($cek_data[0]->tgl_lahir);
$date2 = new DateTime("now");
$interval = $date1->diff($date2);
$main['umur'] = $interval->y;
// echo $main["header"];
$this->load->view('admin/menu/libur', $main);
$main["header"] = "Halaman Topsis";
$main["nik"] = $nik;
$main['nama'] = $cek_data[0]->nama;
$this->load->view('admin/menu/topsis_detail', $main);
} else{
redirect('/admin/topsis');
}
}
function perjalanan_dinas()
{
if ($this->input->post('proses') == "table_dinas") {
$list = $this->m_tabel_ss->get_datatables(array('range_tanggal', 'created_at'), array(null, 'range_tanggal', null, 'created_at', null), array('id_perjalanan_dinas' => 'desc'), "tb_perjalanan_dinas", null, array("id_dinas" => $this->main['id_dinas']), "*");
$data = array();
$no = $_POST['start'];
foreach ($list as $field) {
$list_karyawan = json_decode($field->list_karyawan);
$value_karyawan = '';
foreach ($list_karyawan as $key => $value) {
$check_karyawan = $this->model->tampil_data_where('tb_karyawan', ['nik' => $value])->result();
$value_karyawan .= " " . $check_karyawan[0]->nama . ' ,';
else {
$main["header"] = "Halaman Topsis";
$main["nik"] = $nik;
$this->load->view('admin/menu/topsis', $main);
}
$value_karyawan = rtrim($value_karyawan, ",");
$no++;
$row = array();
$row[] = $no;
$row[] = $field->range_tanggal;
$row[] = $value_karyawan;
$row[] = $field->created_at;
$row[] = "<center><button type='button' onclick='check_info(" . '"' . (string)$field->id_perjalanan_dinas . '"' . ")' title='Check Informasi Perjalanan Dinas' class='btn btn-primary btn-circle btn-sm waves-effect waves-light'><i class='ico zmdi zmdi-info-outline'></i></button></center>";
$data[] = $row;
}
$output = array(
"draw" => $_POST['draw'],
"recordsTotal" => $this->m_tabel_ss->count_all("tb_perjalanan_dinas", null, array("id_dinas" => $this->main['id_dinas']), "*"),
"recordsFiltered" => $this->m_tabel_ss->count_filtered(array('range_tanggal', 'created_at'), array(null, 'range_tanggal', null, 'created_at', null), array('id_perjalanan_dinas' => 'desc'), "tb_perjalanan_dinas", null, array("id_dinas" => $this->main['id_dinas']), "*"),
"data" => $data,
);
//output dalam format JSON
echo json_encode($output);
} else {
$main = $this->main;
$main["header"] = "Halaman Pengaturan Perjalanan Dinas";
// echo $main["header"];
$this->load->view('admin/menu/perjalanan_dinas', $main);
}
}
function laporan($month = null, $year = null)
{
$main = $this->main;
$main["header"] = "Halaman Laporan";
$main["month"] = $month != null ? $month : date("m");
$main["year"] = $year != null ? $year : date("Y");
$main["first_date"] = ($main["month"] == "09" && $main["year"] == 2022) ? 21 : 1;
$main["last_date"] = date("d");
// echo $main["month"].;
// echo $main["year"] . "ini year";
// $i = 21;
// $tanggal = strlen($i) == 1 ? "0" . $i : $i;
// echo $tanggal;
$main['list_karyawan'] = $this->model->tampil_data_where(('tb_karyawan'), ['id_dinas' => $this->main['id_dinas']])->result();
// print_r($main['list_karyawan']);
$this->load->view('admin/menu/laporan', $main);
}
function coba2($month = null, $year = null)
{
$month = $month != null ? $month : date("m");
$year = $year != null ? $year : date("Y");
// echo "sini tampilkan pdf";
$this->load->library('Pdf');
$pdf = new Pdf('P', 'mm', array(210, 297));
$pdf->AddPage();
$pdf->SetFont('times', '', 12);
$html = '
<br><br><br><br>
<table width="100%">
<tr>
<td align="center" style="font-weight:bold">
<u>Daftar Hadir Pegawai</u><br>
Periode ' . $this->model->bulan($month) . ' ' . $year . '
</td>
</tr>
</table>
<style>
.ini {
border-bottom: 1px dotted black;
}
</style>
';
$first_date = ($month == "09" && $year == 2022) ? 21 : 1;
$last_date = date("d");
$check_karyawan = $this->model->tampil_data_where('tb_karyawan', ['id_dinas' => $this->main['id_dinas']])->result();
for ($i = $first_date; $i <= $last_date; $i++) {
$tanggal = strlen($i) == 1 ? "0" . $i : $i;
$html .= '
<br><br>
<table width="100%">
<tr>
<td style="font-weight:bold">Tanggal '. $tanggal . '-' . $month . '-' . $year . '</td>
</tr>
</table>
';
$html .= '
<table width="100%" border="1" class="ini" cellpadding="2" style="font-size:10px">
<tr style="font-weight:bold">
<td>NIP</td>
<td>Nama</td>
<td>Jabatan</td>
<td>Status</td>
<td>Jam Masuk</td>
<td>Jam Istirehat</td>
<td>Jam Masuk Kembali</td>
<td>Jam Pulang</td>
</tr>
';
foreach ($check_karyawan as $key => $value) {
$check_absensi = $this->model->tampil_data_where('tb_absensi_karyawan', ['nik' => $value->nik, "tanggal" => $year . "-" . $month . "-" . $tanggal])->result();
$status = '-';
$jam_masuk = "-";
$jam_istirehat = "-";
$jam_masuk_kembali = "-";
$jam_pulang = "-";
if (count($check_absensi) > 0) {
$status = 'Masuk Kerja';
$jam_masuk = $check_absensi[0]->jam_masuk;
$jam_istirehat = $check_absensi[0]->jam_istirehat ?? '-';
$jam_masuk_kembali = $check_absensi[0]->jam_masuk_kembali ?? '-';
$jam_pulang = $check_absensi[0]->jam_pulang ?? '-';
}
$check_libur = $this->model->tampil_data_where('tb_informasi_libur', ['nik' => $value->nik, "tanggal" => $year . "-" . $month . "-" . $tanggal])->result();
if (count($check_libur) > 0) {
$status = "Libur";
$idnya = $check_libur[0]->id_libur;
}
$check_perjalanan_dinas = $this->model->tampil_data_where('tb_informasi_perjalanan_dinas', ['nik' => $value->nik, "tanggal" => $year . "-" . $month . "-" . $tanggal])->result();
if (count($check_perjalanan_dinas) > 0) {
$status = "Perjalanan Dinas";
$idnya = $check_perjalanan_dinas[0]->id_perjalanan_dinas;
}
$html .= '
<tr style="font-size:8px">
<td>'.$value->nik.'</td>
<td>'.$value->nama.'</td>
<td>'.$value->jabatan.'</td>
<td>'.$status.'</td>
<td>'.$jam_masuk.'</td>
<td>'.$jam_istirehat.'</td>
<td>'.$jam_masuk_kembali.'</td>
<td>'.$jam_pulang.'</td>
</tr>
';
}
$html .= '</table>';
}
$pdf->writeHTML($html, true, false, true, false, '');
$pdf->Output("laporan data pasien.pdf", 'I');
}
}

View File

@ -42,12 +42,12 @@ class Api extends RestController
$username = $this->get('username');
$password = $this->get('password');
$cek_data = $this->model->tampil_data_where('tb_login_admin', ['username' => $username, 'password' => md5($password)])->result();
// $cek_data = $this->model->tampil_data_where('tb_login_admin', ['username' => $username, 'password' => md5($password)])->result();
if (count($cek_data) > 0) {
$cek_data_admin = $this->model->tampil_data_where('tb_admin', ['nik' => $cek_data[0]->nik])->result()[0];
$cek_data_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $cek_data_admin->id_dinas])->result()[0];
$this->session->set_userdata(['nik' => $cek_data_admin->nik, "level" => $cek_data_admin->level, 'id_dinas' => $cek_data_dinas->id_dinas]);
if ($username == 'admin' && $password == 'admin') {
// $cek_data_admin = $this->model->tampil_data_where('tb_admin', ['nik' => $cek_data[0]->nik])->result()[0];
// $cek_data_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $cek_data_admin->id_dinas])->result()[0];
$this->session->set_userdata(['nik' => 'Admin', "level" => 'Admin']);
$this->response(['message' => "Sukses Login", "status" => true], 200);
} else {
$this->session->unset_userdata(array('nik', "level"));
@ -58,487 +58,389 @@ class Api extends RestController
}
public function pengaturan_lokasi_put() // pengaturan titik kordinat dinas
public function penduduk_get() // tampil data penduduk
{
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Failed', 'stat' => false], 401);
$lat = $this->put('lat');
$lng = $this->put('lng');
$id = $this->put('id');
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Not Allowed'], 401);
$nik = $this->get('nik');
$cek_data = $this->model->tampil_data_where('tb_penduduk', ['nik' => $nik])->result();
if (count($cek_data) == 0) return $this->response(['message' => 'Data Tidak Ditemukan', 'data' => null], 400);
if ($lat == null || $lat == '' || $lng == null || $lng == '' || $id == null || $id == '') {
$this->response(['message' => 'Isi Semua Form', 'stat' => false], 401);
$this->response(['message' => 'Data Ditemukan', 'data' => $cek_data[0]], 200);
}
$cek_data = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $id])->result();
if (count($cek_data) > 0) {
$this->model->update('tb_dinas', ['id_dinas' => $id], ['lat' => $lat, 'lng' => $lng]);
$this->session->set_flashdata('info', 'Titik Kordinat Berhasil Diubah');
$this->response(['message' => 'Sukses Tukar Kordinat ' . $cek_data[0]->dinas], 200);
} else {
$this->response(['message' => 'Data Tiada', 'stat' => false], 403);
}
// $this->response(['res' => 'ok','url' => $id], 200);
}
public function pengaturan_radius_put() // pengaturan titik kordinat dinas
public function penduduk_post() // tambah data penduduk
{
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Failed', 'stat' => false], 401);
$radius = $this->put('radius');
$id = $this->put('id');
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Not Allowed'], 401);
if ($radius == null || $radius == '' || $id == null || $id == '') {
$this->response(['message' => 'Isi Semua Form', 'stat' => false], 401);
}
$cek_data = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $id])->result();
if (count($cek_data) > 0) {
$this->model->update('tb_dinas', ['id_dinas' => $id], ['radius' => $radius]);
$this->session->set_flashdata('info', 'Radius Berhasil Diubah');
$this->response(['message' => 'Sukses Ubah Radius ' . $cek_data[0]->dinas], 200);
} else {
$this->response(['message' => 'Data Tiada', 'stat' => false], 403);
}
// $this->response(['res' => 'ok','url' => $id], 200);
}
public function karyawan_post() // penambahan_karyawan
{
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Failed', 'stat' => false], 401);
$id_dinas = $this->post('id_dinas');
// $foto = $_FILES['foto'];
$foto = $this->post('foto') == 'tiada' ? null : $_FILES['foto'];
$nik = $this->post('nik');
$nama = $this->post('nama');
$no_telpon = $this->post('no_telpon');
$jabatan = $this->post('jabatan');
$tgl_lahir = $this->post('tgl_lahir');
$jenis_kelamin = $this->post('jenis_kelamin');
$alamat = $this->post('alamat');
$status_form = $this->post('status_form');
$status = $this->post('status');
$pangkat = $this->post('pangkat');
$status = $this->post('status');
$tanggal_lahir = $this->post('tanggal_lahir');
$no_hp = $this->post('no_hp');
if ($id_dinas == null || $id_dinas == '' || $nik == null || $nik == '' || $nama == null || $nama == '' || $no_telpon == null || $no_telpon == '' || $jabatan == null || $jabatan == '' || $alamat == null || $alamat == '' || $status_form == null || $status_form == '' || $pangkat == null || $pangkat == '' || $tanggal_lahir == null || $tanggal_lahir == '') {
$this->response(['message' => 'Isi Semua Form', 'stat' => false], 401);
$cek_nik = $this->model->tampil_data_where('tb_penduduk', ['nik' => $nik])->result();
if (count($cek_nik) > 0) return $this->response(['message' => 'NIK ' . $nik . ' sudah terdaftar'], 400);
$data = [
'nik' => $nik,
'nama' => $nama,
'tgl_lahir' => $tgl_lahir,
'jenis_kelamin' => $jenis_kelamin,
'alamat' => $alamat,
'no_hp' => $no_hp,
];
$this->model->insert('tb_penduduk', $data);
$this->response(['message' => 'Data dengan NIK ' . $nik . ' berhasil ditambahkan'], 200);
}
$cek_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $id_dinas])->result();
if (count($cek_dinas) == 0) return $this->response(['message' => 'Dinas Tidak Ditemukan', 'stat' => false], 401);
if ($status_form == 'tambah') {
$cek_data = $this->model->tampil_data_where('tb_karyawan', ['nik' => $nik])->result();
if (count($cek_data) > 0) {
$this->response(['message' => 'Karyawan Dengan NIK ' . $nik . " telah terdaftar di sistem", 'stat' => false], 403);
} else {
$dir = "assets/images/foto_karyawan/$nik/";
if (is_dir($dir) === false) {
mkdir($dir);
}
$path = $dir . $foto['name'];
move_uploaded_file($foto['tmp_name'], $path);
$image_path = $path;
$this->model->insert("tb_karyawan", ['nik' => $nik, 'nama' => $nama, 'no_telpon' => $no_telpon, 'jabatan' => $jabatan, 'alamat' => $alamat, "id_dinas" => $id_dinas, "image" => $image_path, "status" => $status, "pangkat" => $pangkat, "tanggal_lahir" => $tanggal_lahir]);
$this->model->insert("tb_login_user", ["username" => $nik, "password" => md5("12345678"), "nik" => $nik]);
$this->response(['message' => 'Karyawan Dengan NIK ' . $nik . " berhasil didaftar di sistem\nUsername : " . $nik . "\nPassword : 12345678"], 201);
}
}
if ($status_form == 'edit') {
$cek_data = $this->model->tampil_data_where('tb_karyawan', ['nik' => $nik, "id_dinas" => $id_dinas])->result();
if (count($cek_data) == 0) return $this->response(['message' => 'Karyawan Tidak Ditemukan', 'stat' => false], 401);
if ($foto == null) {
$this->model->update("tb_karyawan", ['nik' => $nik, "id_dinas" => $id_dinas], ["nama" => $nama, "no_telpon" => $no_telpon, "jabatan" => $jabatan, "alamat" => $alamat, "status" => $status, "pangkat" => $pangkat, "tanggal_lahir" => $tanggal_lahir]);
} else {
$dir = "assets/images/foto_karyawan/$nik/";
if (is_dir($dir) === false) {
mkdir($dir);
}
$files = glob($dir . '*'); // get all file names
foreach ($files as $file) { // iterate files
if (is_file($file)) {
unlink($file); // delete file
}
}
$path = $dir . $foto['name'];
move_uploaded_file($foto['tmp_name'], $path);
$image_path = $path;
$this->model->update("tb_karyawan", ['nik' => $nik, "id_dinas" => $id_dinas], ["nama" => $nama, "no_telpon" => $no_telpon, "jabatan" => $jabatan, "alamat" => $alamat, "image" => $image_path, "status" => $status, "pangkat" => $pangkat, "tanggal_lahir" => $tanggal_lahir]);
}
$this->response(['message' => 'Data Karyawan Berhasil Diubah'], 200);
}
// $this->response(['res' => 'ok', 'url' => $status], 200);
}
public function karyawanAll_get()
public function penduduk_put() // edit data penduduk
{
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Failed', 'stat' => false], 401);
$check_data = $this->model->tampil_data_keseluruhan('tb_karyawan')->result();
$this->response(['data' => $check_data], 200);
}
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Not Allowed'], 401);
public function karyawan_get() // ambil data karyawan
{
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Failed', 'stat' => false], 401);
$id_dinas = $this->get('id_dinas');
$nik = $this->get('nik');
if ($id_dinas == null || $id_dinas == '' || $nik == null || $nik == '') {
$this->response(['message' => 'Isi Semua Form', 'stat' => false], 401);
}
$cek_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $id_dinas])->result();
if (count($cek_dinas) == 0) return $this->response(['message' => 'Dinas Tidak Ditemukan', 'stat' => false], 401);
$cek_data = $this->model->tampil_data_where('tb_karyawan', ['nik' => $nik])->result();
if (count($cek_data) == 0) return $this->response(['message' => 'Karyawan Tidak Ditemukan', 'stat' => false], 401);
$this->response(['data' => $cek_data[0]], 200);
// $this->response(['message' => 'Karyawan Tidak Ditemukan', 'stat' => false], 401);
}
public function karyawan_put() // edit data karyawan
{
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Failed', 'stat' => false], 401);
$id_dinas = $this->put('id_dinas');
$foto = $_FILES['foto'];
$nik = $this->put('nik');
$nama = $this->put('nama');
$no_telpon = $this->put('no_telpon');
$jabatan = $this->put('jabatan');
$tgl_lahir = $this->put('tgl_lahir');
$jenis_kelamin = $this->put('jenis_kelamin');
$alamat = $this->put('alamat');
$no_hp = $this->put('no_hp');
// if ($id_dinas == null || $id_dinas == '' || $nik == null || $nik == '' || $nama == null || $nama == '' || $no_telpon == null || $no_telpon == '' || $jabatan == null || $jabatan == '' || $alamat == null || $alamat == '') {
// $this->response(['message' => 'Isi Semua Form', 'stat' => false], 401);
// }
$cek_nik = $this->model->tampil_data_where('tb_penduduk', ['nik' => $nik])->result();
// $cek_dinas = $this->model->tampil_data_where('tb_dinas',['id_dinas' => $id_dinas])->result();
if (count($cek_nik) == 0) return $this->response(['message' => 'NIK ' . $nik . ' tidak terdaftar'], 400);
// if(count($cek_dinas) == 0) return $this->response(['message' => 'Dinas Tidak Ditemukan', 'stat' => false], 401);
$data = [
'nama' => $nama,
'tgl_lahir' => $tgl_lahir,
'jenis_kelamin' => $jenis_kelamin,
'alamat' => $alamat,
'no_hp' => $no_hp,
];
$this->model->update('tb_penduduk', ['nik' => $nik], $data);
// $cek_data = $this->model->tampil_data_where('tb_karyawan', ['nik' => $nik, "id_dinas" => $id_dinas])->result();
// if (count($cek_data) == 0) return $this->response(['message' => 'Karyawan Tidak Ditemukan', 'stat' => false], 401);
// $this->model->update("tb_karyawan",['nik' => $nik, "id_dinas" => $id_dinas], ["nama" => $nama , "no_telpon" => $no_telpon , "jabatan" => $jabatan, "alamat" => $alamat]);
// $this->response(['message' => '"Data Karyawan Berhasil Diubah'], 200);
$this->response(['message' => $foto], 200);
$this->response(['message' => 'Data dengan NIK ' . $nik . ' berhasil diubah'], 200);
}
public function karyawan_delete() // edit data karyawan
public function penduduk_delete() // hapus data penduduk
{
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Failed', 'stat' => false], 401);
$id_dinas = $this->delete('id_dinas');
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Not Allowed'], 401);
$nik = $this->delete('nik');
$cek_nik = $this->model->tampil_data_where('tb_penduduk', ['nik' => $nik])->result();
if ($id_dinas == null || $id_dinas == '' || $nik == null || $nik == '') {
$this->response(['message' => 'Isi Semua Form', 'stat' => false], 401);
if (count($cek_nik) == 0) return $this->response(['message' => 'NIK ' . $nik . ' tidak terdaftar'], 400);
$this->model->delete('tb_penduduk', ['nik' => $nik]);
$this->response(['message' => 'Data dengan NIK ' . $nik . ' berhasil dihapus'], 200);
// $this -> response(['message' => $nik], 200);
}
$cek_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $id_dinas])->result();
if (count($cek_dinas) == 0) return $this->response(['message' => 'Dinas Tidak Ditemukan', 'stat' => false], 401);
$cek_data = $this->model->tampil_data_where('tb_karyawan', ['nik' => $nik, "id_dinas" => $id_dinas])->result();
if (count($cek_data) == 0) return $this->response(['message' => 'Karyawan Tidak Ditemukan', 'stat' => false], 401);
$this->model->delete("tb_karyawan", ['nik' => $nik, "id_dinas" => $id_dinas]);
$this->response(['message' => "Data Karyawan Berhasil Dihapus"], 200);
}
public function jam_kerja_post() // edit data karyawan
public function topsis_get()
{
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Failed', 'stat' => false], 401);
$id_dinas = $this->post('id_dinas');
$hari = $this->post('hari');
$jam_masuk = $this->post('jam_masuk');
$jam_istirehat = $this->post('jam_istirehat');
$jam_masuk_kembali = $this->post('jam_masuk_kembali');
$jam_pulang = $this->post('jam_pulang');
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Not Allowed'], 401);
$nik = $this->get('nik');
$cek_nik = $this->model->tampil_data_where('tb_penduduk', ['nik' => $nik])->result();
if ($id_dinas == null || $id_dinas == '' || $hari == null || $hari == '' || $jam_masuk == null || $jam_masuk == '' || $jam_istirehat == null || $jam_istirehat == '' || $jam_masuk_kembali == null || $jam_masuk_kembali == '' || $jam_pulang == null || $jam_pulang == '') {
$this->response(['message' => 'Isi Semua Form', 'stat' => false], 401);
}
$cek_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $id_dinas])->result();
if (count($cek_dinas) == 0) return $this->response(['message' => 'Dinas Tidak Ditemukan', 'stat' => false], 401);
$cek_data = $this->model->tampil_data_where('tb_pengaturan_jam_kerja_harian', ['hari' => $hari, "id_dinas" => $id_dinas])->result();
if (count($cek_nik) == 0) return $this->response(['message' => 'NIK ' . $nik . ' tidak terdaftar'], 400);
$cek_data = $this->model->tampil_data_where('tb_detail', ['nik' => $nik])->result();
if (count($cek_data) == 0) {
$this->model->insert("tb_pengaturan_jam_kerja_harian", ['hari' => $hari, "id_dinas" => $id_dinas, "jam_masuk" => $jam_masuk, "jam_istirehat" => $jam_istirehat, "jam_masuk_kembali" => $jam_masuk_kembali, "jam_pulang" => $jam_pulang]);
$this->response(['message' => 'Data Tidak Ditemukan', 'data' => null], 200);
} else {
$this->model->update("tb_pengaturan_jam_kerja_harian", ['hari' => $hari, "id_dinas" => $id_dinas], ["jam_masuk" => $jam_masuk, "jam_istirehat" => $jam_istirehat, "jam_masuk_kembali" => $jam_masuk_kembali, "jam_pulang" => $jam_pulang]);
$this->response(['message' => 'Data Ditemukan', 'data' => $cek_data[0]], 200);
}
// $this->model->delete("tb_karyawan",['nik' => $nik, "id_dinas" => $id_dinas]);
// $this->session->set_flashdata('info',"Jam Kerja Hari ".ucfirst($hari)." Berhasil Diubah");
$this->response(['message' => "Jam Kerja Hari " . ucfirst($hari), " Berhasil Diubah"], 200);
}
public function jam_kerja_get() // edit data karyawan
public function topsis_post()
{
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Failed', 'stat' => false], 401);
$id_dinas = $this->get('id_dinas');
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Not Allowed'], 401);
$nik = $this->post('nik');
$bobot_umur = $this->post('bobot_umur');
$bobot_pekerjaan = $this->post('bobot_pekerjaan');
$bobot_penghasilan = $this->post('bobot_penghasilan');
$bobot_jumlah_tanggungan = $this->post('bobot_jumlah_tanggungan');
$bobot_jenis_rumah = $this->post('bobot_jenis_rumah');
$cek_nik = $this->model->tampil_data_where('tb_penduduk', ['nik' => $nik])->result();
if ($id_dinas == null || $id_dinas == '') {
$this->response(['message' => 'Isi Semua Form', 'stat' => false], 401);
}
if (count($cek_nik) == 0) return $this->response(['message' => 'NIK ' . $nik . ' tidak terdaftar'], 400);
$cek_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $id_dinas])->result();
if (count($cek_dinas) == 0) return $this->response(['message' => 'Dinas Tidak Ditemukan', 'stat' => false], 401);
$cek_data = $this->model->tampil_data_where('tb_pengaturan_jam_kerja_harian', ["id_dinas" => $id_dinas])->result();
$this->response(['data' => $cek_data], 200);
$data = [
'bobot_umur' => $bobot_umur,
'bobot_pekerjaan' => $bobot_pekerjaan,
'bobot_penghasilan' => $bobot_penghasilan,
'bobot_jumlah_tanggungan' => $bobot_jumlah_tanggungan,
'bobot_jenis_rumah' => $bobot_jenis_rumah,
];
$cek_data = $this->model->tampil_data_where('tb_detail', ['nik' => $nik])->result();
if (count($cek_data) == 0) {
$data['nik'] = $nik;
$this->model->insert('tb_detail', $data);
} else {
$this->model->update('tb_detail', ['nik' => $nik], $data);
}
public function libur_post()
$this->response(['message' => ""], 200);
}
public function bantuan_get()
{
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Failed', 'stat' => false], 401);
$id_dinas = $this->post('id_dinas');
$list_karyawan = $this->post('list_karyawan');
$start_tanggal = $this->post('start_tanggal');
$end_tanggal = $this->post('end_tanggal');
$ket = $this->post('ket');
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Not Allowed'], 401);
if ($id_dinas == null || $id_dinas == '' || $list_karyawan == null || $list_karyawan == '' || $start_tanggal == null || $start_tanggal == '' || $end_tanggal == null || $end_tanggal == '' || $ket == null || $ket == '') {
$this->response(['message' => 'Isi Semua Form', 'stat' => false], 401);
$cek_detail = $this->model->tampil_data_keseluruhan('tb_detail')->result();
$bobotall = [];
foreach ($cek_detail as $key => $value) {
$array = [
$value->bobot_umur,
$value->bobot_pekerjaan,
$value->bobot_penghasilan,
$value->bobot_jumlah_tanggungan,
$value->bobot_jenis_rumah,
];
array_push($bobotall, $array);
}
$cek_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $id_dinas])->result();
$the_bobotall = [];
foreach ($cek_detail as $key => $value) {
$array = [
'nik' => $value->nik,
'kriteria_umur' => $value->bobot_umur,
'kriteria_pekerjaan' => $value->bobot_pekerjaan,
'kriteria_penghasilan' => $value->bobot_penghasilan,
'kriteria_jumlah_tanggungan' => $value->bobot_jumlah_tanggungan,
'kriteria_jenis_rumah' => $value->bobot_jenis_rumah,
if (count($cek_dinas) == 0) return $this->response(['message' => 'Dinas Tidak Ditemukan', 'stat' => false], 401);
$period = new DatePeriod(
new DateTime($start_tanggal),
new DateInterval('P1D'),
new DateTime($end_tanggal)
);
$cek_last_ai = $this->model->cek_last_ai('tb_libur');
$this->model->insert('tb_libur', ['id_dinas' => $id_dinas, 'list_karyawan' => $list_karyawan, 'range_tanggal' => $start_tanggal . " - " . $end_tanggal, 'ket' => $ket . " (" . $start_tanggal . " - " . $end_tanggal . ")", 'created_at' => date("Y-m-d H:i:s")]);
$converted_list_karyawan = json_decode($list_karyawan);
foreach ($converted_list_karyawan as $key1 => $value1) {
foreach ($period as $key => $value) {
$this->model->insert('tb_informasi_libur', ['id_libur' => $cek_last_ai, 'nik' => $value1, "tanggal" => $value->format('Y-m-d'), 'ket' => $ket . " (" . $start_tanggal . " - " . $end_tanggal . ")"]);
}
$this->model->insert('tb_informasi_libur', ['id_libur' => $cek_last_ai, 'nik' => $value1, "tanggal" => $end_tanggal, 'ket' => $ket . " (" . $start_tanggal . " - " . $end_tanggal . ")"]);
}
$this->response(['message' => "Data Libur Berhasil Dimasukkan"], 200);
];
array_push($the_bobotall, $array);
}
public function libur_get()
$bobot = [4, 4, 4, 4, 4];
$matriks_keputusan = $this->MatrixKeputusan($bobotall);
$the_matrix_keputusan = [];
foreach ($cek_detail as $key => $value) {
$array = [
'nik' => $cek_detail[$key]->nik,
'kriteria_umur' => $matriks_keputusan[$key][0],
'kriteria_pekerjaan' => $matriks_keputusan[$key][1],
'kriteria_penghasilan' => $matriks_keputusan[$key][2],
'kriteria_jumlah_tanggungan' => $matriks_keputusan[$key][3],
'kriteria_jenis_rumah' => $matriks_keputusan[$key][4],
];
array_push($the_matrix_keputusan, $array);
}
$totalmatriks_keputusan = $this->TotMatrixKeputusan($matriks_keputusan);
$matriks_normalisasi = $this->MatrixTernormalisasi($bobotall, $totalmatriks_keputusan);
$the_matrix_normalisasi = [];
foreach ($cek_detail as $key => $value) {
$array = [
'nik' => $cek_detail[$key]->nik,
'kriteria_umur' => $matriks_normalisasi[$key][0],
'kriteria_pekerjaan' => $matriks_normalisasi[$key][1],
'kriteria_penghasilan' => $matriks_normalisasi[$key][2],
'kriteria_jumlah_tanggungan' => $matriks_normalisasi[$key][3],
'kriteria_jenis_rumah' => $matriks_normalisasi[$key][4],
];
array_push($the_matrix_normalisasi, $array);
}
$normalisasi_terbobot = $this->TermTerbobot($matriks_normalisasi, $bobot);
$the_normalisasi_terbobot = [];
foreach ($cek_detail as $key => $value) {
$array = [
'nik' => $cek_detail[$key]->nik,
'kriteria_umur' => $normalisasi_terbobot[$key][0],
'kriteria_pekerjaan' => $normalisasi_terbobot[$key][1],
'kriteria_penghasilan' => $normalisasi_terbobot[$key][2],
'kriteria_jumlah_tanggungan' => $normalisasi_terbobot[$key][3],
'kriteria_jenis_rumah' => $normalisasi_terbobot[$key][4],
];
array_push($the_normalisasi_terbobot, $array);
$this->model->update('tb_detail', ['nik' => $cek_detail[$key]->nik], ['normalisasi' => json_encode($normalisasi_terbobot[$key])]);
}
$ideal_positif = $this->SolusiIdealPositif($normalisasi_terbobot);
$the_ideal_positif = [
'kriteria_umur' => $ideal_positif[0],
'kriteria_pekerjaan' => $ideal_positif[1],
'kriteria_penghasilan' => $ideal_positif[2],
'kriteria_jumlah_tanggungan' => $ideal_positif[3],
'kriteria_jenis_rumah' => $ideal_positif[4],
];
$ideal_negatif = $this->SolusiIdealNegatif($normalisasi_terbobot);
$the_ideal_negatif = [
'kriteria_umur' => $ideal_negatif[0],
'kriteria_pekerjaan' => $ideal_negatif[1],
'kriteria_penghasilan' => $ideal_negatif[2],
'kriteria_jumlah_tanggungan' => $ideal_negatif[3],
'kriteria_jenis_rumah' => $ideal_negatif[4],
];
$solusiideal = array();
$solusiideal[] = $ideal_positif;
$solusiideal[] = $ideal_negatif;
$jarak_solusi = $this->JarakSolusi($normalisasi_terbobot, $solusiideal);
$preverensi = $this->Preverensi($jarak_solusi);
$the_preverensi = [];
foreach ($cek_detail as $key => $value) {
$array = [
'nik' => $cek_detail[$key]->nik,
'preverensi' => $preverensi[$key],
];
array_push($the_preverensi, $array);
$this->model->update('tb_detail', ['nik' => $cek_detail[$key]->nik], ['preverensi' => json_encode($preverensi[$key])]);
$status = ($preverensi[$key] >= 0.5) ? 'Layak' : 'Tidak Layak';
$this->model->update('tb_detail', ['nik' => $cek_detail[$key]->nik], ['status' => $status]);
}
$this->response(["bobot" => $the_bobotall, 'matriks_keputusan' => $the_matrix_keputusan, "matriks_normalisasi" => $the_matrix_normalisasi, 'normalisasi_terbobot' => $the_normalisasi_terbobot, 'ideal_positif' => $the_ideal_positif, "ideal_negatif" => $the_ideal_negatif, 'preverensi' => $the_preverensi], 200);
}
function MatrixKeputusan($matrix)
{
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Failed', 'stat' => false], 401);
$id_dinas = $this->get('id_dinas');
$id_libur = $this->get('id_libur');
if ($id_dinas == null || $id_dinas == '' || $id_libur == null || $id_libur == '') {
$this->response(['message' => 'Isi Semua Form', 'stat' => false], 401);
$all = [];
for ($i = 0; $i < count($matrix); $i++) {
$bobot = [];
for ($j = 0; $j < count($matrix[$i]); $j++) {
$x = $matrix[$i][$j] ** 2;
array_push($bobot, $x);
}
array_push($all, $bobot);
}
return $all;
}
$cek_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $id_dinas])->result();
if (count($cek_dinas) == 0) return $this->response(['message' => 'Dinas Tidak Ditemukan', 'stat' => false], 401);
$check_data = $this->model->tampil_data_where('tb_libur', ['id_libur' => $id_libur, "id_dinas" => $id_dinas])->result();
if (count($check_data) == 0) return $this->response(['message' => 'Informasi Libur Tidak Ditemukan', 'stat' => false], 401);
$data = array();
$data['range_tanggal'] = $check_data[0]->range_tanggal;
$data['ket'] = $check_data[0]->ket;
$data['created_at'] = $check_data[0]->created_at;
$data['list_karyawan'] = '';
$list_karyawan = json_decode($check_data[0]->list_karyawan);
foreach ($list_karyawan as $key => $value) {
$check_karyawan = $this->model->tampil_data_where('tb_karyawan', ['nik' => $value])->result();
$data['list_karyawan'] .= " " . $check_karyawan[0]->nama . ' ,';
}
$data['list_karyawan'] = rtrim($data['list_karyawan'] ,",");
$this->response(['data' => $data], 200);
}
public function perjalanan_dinas_post()
function TotMatrixKeputusan($matrix)
{
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Failed', 'stat' => false], 401);
$id_dinas = $this->post('id_dinas');
$list_karyawan = $this->post('list_karyawan');
$start_tanggal = $this->post('start_tanggal');
$end_tanggal = $this->post('end_tanggal');
$ket = $this->post('ket');
if ($id_dinas == null || $id_dinas == '' || $list_karyawan == null || $list_karyawan == '' || $start_tanggal == null || $start_tanggal == '' || $end_tanggal == null || $end_tanggal == '' || $ket == null || $ket == '') {
$this->response(['message' => 'Isi Semua Form', 'stat' => false], 401);
$total = [];
for ($i = 0; $i < count($matrix[0]); $i++) {
$tot = 0;
for ($j = 0; $j < count($matrix); $j++) {
$tot += $matrix[$j][$i];
}
$total[] = $tot ** (1 / 2);
}
return $total;
}
$cek_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $id_dinas])->result();
if (count($cek_dinas) == 0) return $this->response(['message' => 'Dinas Tidak Ditemukan', 'stat' => false], 401);
$period = new DatePeriod(
new DateTime($start_tanggal),
new DateInterval('P1D'),
new DateTime($end_tanggal)
);
$cek_last_ai = $this->model->cek_last_ai('tb_perjalanan_dinas');
$this->model->insert('tb_perjalanan_dinas', ['id_dinas' => $id_dinas, 'list_karyawan' => $list_karyawan, 'range_tanggal' => $start_tanggal . " - " . $end_tanggal, 'ket' => $ket . " (" . $start_tanggal . " - " . $end_tanggal . ")", 'created_at' => date("Y-m-d H:i:s")]);
$converted_list_karyawan = json_decode($list_karyawan);
foreach ($converted_list_karyawan as $key1 => $value1) {
foreach ($period as $key => $value) {
$this->model->insert('tb_informasi_perjalanan_dinas', ['id_perjalanan_dinas' => $cek_last_ai, 'nik' => $value1, "tanggal" => $value->format('Y-m-d'), 'ket' => $ket . " (" . $start_tanggal . " - " . $end_tanggal . ")"]);
}
$this->model->insert('tb_informasi_perjalanan_dinas', ['id_perjalanan_dinas' => $cek_last_ai, 'nik' => $value1, "tanggal" => $end_tanggal, 'ket' => $ket . " (" . $start_tanggal . " - " . $end_tanggal . ")"]);
}
$this->response(['message' => "Data Libur Berhasil Dimasukkan"], 200);
}
public function perjalanan_dinas_get()
function MatrixTernormalisasi($matrix1, $matrix2)
{
if ($this->session->userdata('level') != 'Admin') return $this->response(['message' => 'Failed', 'stat' => false], 401);
$id_dinas = $this->get('id_dinas');
$id_perjalanan_dinas = $this->get('id_perjalanan_dinas');
if ($id_dinas == null || $id_dinas == '' || $id_perjalanan_dinas == null || $id_perjalanan_dinas == '') {
$this->response(['message' => 'Isi Semua Form', 'stat' => false], 401);
$total = $matrix2;
$all = [];
for ($i = 0; $i < count($matrix1); $i++) {
$sub = [];
$k = 0;
for ($j = 0; $j < count($matrix1[$i]); $j++) {
$x = $matrix1[$i][$j] / $total[$k];
array_push($sub, $x);
$k++;
}
array_push($all, $sub);
}
return $all;
}
$cek_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $id_dinas])->result();
if (count($cek_dinas) == 0) return $this->response(['message' => 'Dinas Tidak Ditemukan', 'stat' => false], 401);
$check_data = $this->model->tampil_data_where('tb_perjalanan_dinas', ['id_perjalanan_dinas' => $id_perjalanan_dinas, "id_dinas" => $id_dinas])->result();
if (count($check_data) == 0) return $this->response(['message' => 'Informasi Libur Tidak Ditemukan', 'stat' => false], 401);
$data = array();
$data['range_tanggal'] = $check_data[0]->range_tanggal;
$data['ket'] = $check_data[0]->ket;
$data['created_at'] = $check_data[0]->created_at;
$data['list_karyawan'] = '';
$list_karyawan = json_decode($check_data[0]->list_karyawan);
foreach ($list_karyawan as $key => $value) {
$check_karyawan = $this->model->tampil_data_where('tb_karyawan', ['nik' => $value])->result();
$data['list_karyawan'] .= " " . $check_karyawan[0]->nama . ' ,';
}
$data['list_karyawan'] = rtrim($data['list_karyawan'] ,",");
$this->response(['data' => $data], 200);
}
public function get_today_absensi_get()
function TermTerbobot($matrix, $bobot)
{
$id_dinas = $this->get('id_dinas');
if ($id_dinas == null || $id_dinas == '') {
$this->response(['message' => 'Isi Semua Form', 'stat' => false], 401);
$all = array();
for ($i = 0; $i < count($matrix); $i++) {
$sub = array();
$k = 0;
for ($j = 0; $j < count($matrix[$i]); $j++) {
$sub[] = $matrix[$i][$j] * $bobot[$k];
$k++;
}
$all[] = $sub;
}
return $all;
}
$cek_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $id_dinas])->result();
if (count($cek_dinas) == 0) return $this->response(['message' => 'Dinas Tidak Ditemukan', 'stat' => false], 401);
$today = date("Y-m-d");
$check_data = $this->model->tampil_data_where('tb_absensi_karyawan', ['id_dinas' => $id_dinas, 'tanggal' => $today])->result();
$datanya = array();
if (count($check_data) > 0) {
foreach ($check_data as $key => $value) {
$check_data_karyawan = $this->model->tampil_data_where('tb_karyawan', ['nik' => $value->nik])->result();
$check_kordinat = $this->model->tampil_data_where('tb_kordinat_karyawan', ['nik' => $value->nik])->result();
$status = "Sedang Bekerja";
if ($check_data[$key]->jam_istirehat != null) {
$status = "Sedang Istirehat";
function SolusiIdealPositif($matrix)
{
$all = array();
for ($i = 0; $i < count($matrix[0]); $i++) {
$sub = array();
for ($j = 0; $j < count($matrix); $j++) {
array_push($sub, $matrix[$j][$i]);
}
if ($check_data[$key]->jam_masuk_kembali != null) {
$status = "Sedang Bekerja";
array_push($all, $sub);
}
if ($check_data[$key]->jam_pulang != null) {
$status = "Pulang Kerja";
$sub1 = array();
for ($k = 0; $k < count($all); $k++) {
if ($all[$k] == $all[0] || $all[$k] == $all[2]) {
$val = min($all[$k]);
} else {
$val = max($all[$k]);
}
array_push($sub1, $val);
}
return $sub1;
}
$datanya[$key]['nik'] = $value->nik;
$datanya[$key]['nama'] = $check_data_karyawan[0]->nama;
$datanya[$key]['lat'] = floatval($check_kordinat[0]->lat);
$datanya[$key]['lng'] = floatval($check_kordinat[0]->lng);
$datanya[$key]['last_updated'] = $check_kordinat[0]->updated_at;
$datanya[$key]['status'] = $status;
function SolusiIdealNegatif($matrix)
{
$all = [];
for ($i = 0; $i < count($matrix[0]); $i++) {
$sub = [];
for ($j = 0; $j < count($matrix); $j++) {
$sub[] = $matrix[$j][$i];
}
$all[] = $sub;
}
$sub1 = [];
for ($k = 0; $k < count($all); $k++) {
if ($all[$k] == $all[0] || $all[$k] == $all[2]) {
$val = max($all[$k]);
} else {
$val = min($all[$k]);
}
$sub1[] = $val;
}
return $sub1;
}
function JarakSolusi($matrix1, $matrix2)
{
$all = [];
for ($n = 0; $n < 2; $n++) {
$solution = [];
for ($i = 0; $i < count($matrix1); $i++) {
$sub = [];
$k = 0;
for ($j = 0; $j < count($matrix1[$i]); $j++) {
$x = $matrix1[$i][$j] - $matrix2[$n][$k];
$sub[] = $x ** 2;
$k += 1;
}
$solution[] = array_sum($sub) ** (1 / 2);
}
$all[] = $solution;
}
return $all;
}
$this->response(['data' => $datanya], 200);
function Preverensi($matrix)
{
$all = array();
for ($i = 0; $i < count($matrix[0]); $i++) {
$all[] = $matrix[1][$i] / ($matrix[1][$i] + $matrix[0][$i]);
}
return $all;
}
}

View File

@ -1,269 +0,0 @@
<?php
header('Access-Control-Allow-Origin: *');
header('Access-Control-Allow-Methods: GET, POST, DELETE, PUT');
header('Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept, Authorization');
header('Access-Control-Allow-Credentials: true');
header('Content-Type: application/json');
defined('BASEPATH') or exit('No direct script access allowed');
use chriskacerguis\RestServer\RestController;
class Apiuser extends RestController
{
function __construct()
{
parent::__construct();
$this->load->model('model');
// $this->db->query("SET sql_mode = '' ");
date_default_timezone_set("Asia/Kuala_Lumpur");
}
public function index_get()
{
$this->response(['message' => 'Halo Bosku'], 200);
}
// -----------------------------------------------------------------------------------------------------------
public function login_post() // login user
{
$nik = $this->post('nik');
$password = $this->post('password');
$device_id = $this->post('device_id');
if ($nik == null || $nik == '' || $password == null || $password == '' || $device_id == null || $device_id == '') return $this->response(['status' => false, 'message' => "Isi Semua Form"], 403);
$cek_data = $this->model->tampil_data_where('tb_login_user', ['username' => $nik, 'password' => md5($password)])->result();
if (count($cek_data) == 0) return $this->response(['status' => false, 'message' => "Username Dan Password Salah"], 401);
$data_user = $this->model->custom_query("SELECT * from tb_karyawan a join tb_dinas b on a.id_dinas = b.id_dinas where a.nik=$nik")->result()[0];
if ($data_user->device_id == null || $data_user->device_id == '') {
$cek_if_device_exist = $this->model->tampil_data_where('tb_karyawan', ['device_id' => $device_id])->result();
if (count($cek_if_device_exist) > 0) return $this->response(['status' => false, 'message' => "Gagal Login Ke Perangkat Ini, Perangkat Ini Telah Terdaftar Ke Karayawan Lainnya, Sila Infokan Ke Admin Bersangkutan Jika Ingin Ganti Perangkat Anda"], 403);
$this->model->update("tb_karyawan", ['nik' => $nik], ['device_id' => $device_id, "updated_at" => date("Y-m-d H:i:s")]);
return $this->response(['status' => true, 'message' => "Selamat Login " . $data_user->nama, "data" => $data_user, "firstTime" => true], 200);
} else {
if ($device_id != $data_user->device_id) return $this->response(['status' => false, 'message' => "Gagal Login Ke Perangkat Ini,Login Ke Perangkat Yang Anda Gunakan Sebelumnya. Sila Infokan Ke Admin Bersangkutan Jika Ingin Ganti Perangkat Anda"], 403);
$this->response(['status' => true, 'message' => "Selamat Login " . $data_user->nama, "data" => $data_user], 200);
}
}
public function user_data_get() //get user data
{
$nik = $this->get('nik');
if ($nik == null || $nik == '') return $this->response(['status' => false, 'message' => "Isi Semua Form"], 403);
$data_user = $this->model->custom_query("SELECT * from tb_karyawan a join tb_dinas b on a.id_dinas = b.id_dinas where a.nik=$nik")->result();
if (count($data_user) == 0) return $this->response(['status' => false, 'message' => "Tiada Data"], 401);
$this->response(['status' => true, 'message' => "Sukses mengambil data", "data" => $data_user[0]], 200);
}
public function jadwal_dinas_post() // ambil jadwal absesni instansi
{
$id_dinas = $this->post('id_dinas');
if ($id_dinas == null || $id_dinas == '') return $this->response(['status' => false, 'message' => "Isi Semua Form"], 403);
$check_dinas = $this->model->tampil_data_where('tb_dinas', ['id_dinas' => $id_dinas])->result();
if (count($check_dinas) == 0) return $this->response(['status' => false, 'message' => "Tiada Data"], 401);
$data_kerja_dinas = $this->model->tampil_data_where('tb_pengaturan_jam_kerja_harian', ['id_dinas' => $id_dinas])->result();
$this->response(['status' => true, 'message' => "Sukses mengambil data jadawal kerja", "data" => $data_kerja_dinas], 200);
}
public function today_absensi_get() // ambil absensi ini hari berdasarkan kayawan
{
$nik = $this->get('nik');
$date = $this->get('date');
if ($nik == null || $nik == '' || $date == null || $date == '') return $this->response(['status' => false, 'message' => "Isi Semua Form"], 403);
$check_karyawan = $this->model->tampil_data_where('tb_karyawan', ['nik' => $nik])->result();
if (count($check_karyawan) == 0) return $this->response(['status' => false, 'message' => "Tiada Data"], 401);
$check_data_absensi = $this->model->tampil_data_where('tb_absensi_karyawan', ['nik' => $nik, 'tanggal' => $date])->result();
if (count($check_data_absensi) > 0) {
$this->response(['status' => true, 'message' => "Sukses mengambil data jadawal karyawan", "data" => $check_data_absensi[0]], 200);
} else {
$this->response(['status' => true, 'message' => "Sukses mengambil data jadawal karyawan", "data" => null], 200);
}
}
public function today_absensi_post() // ambil absensi ini hari berdasarkan kayawan
{
$nik = $this->post('nik');
$date = $this->post('date');
$stat = $this->post('stat');
if ($nik == null || $nik == '' || $date == null || $date == '' || $stat == null || $stat == '') return $this->response(['status' => false, 'message' => "Isi Semua Form"], 403);
$check_karyawan = $this->model->tampil_data_where('tb_karyawan', ['nik' => $nik])->result();
if (count($check_karyawan) == 0) return $this->response(['status' => false, 'message' => "Tiada Data"], 401);
$time = date('H:i:s');
$check_data_absensi = $this->model->tampil_data_where('tb_absensi_karyawan', ['nik' => $nik, 'tanggal' => $date])->result();
if (count($check_data_absensi) > 0) {
if ($stat == 'jam_istirehat') {
$this->model->update('tb_absensi_karyawan', ['nik' => $nik, 'tanggal' => $date], [
'jam_istirehat' => $time
]);
}
if ($stat == 'jam_masuk_kembali') {
$this->model->update('tb_absensi_karyawan', ['nik' => $nik, 'tanggal' => $date], [
'jam_masuk_kembali' => $time
]);
}
if ($stat == 'jam_pulang') {
$this->model->update('tb_absensi_karyawan', ['nik' => $nik, 'tanggal' => $date], [
'jam_pulang' => $time
]);
}
$this->response(['status' => true, 'message' => "Sukses mengambil data jadawal karyawan", "data" => $check_data_absensi[0]], 200);
} else {
if ($stat != 'jam_masuk') return $this->response(['status' => false, 'message' => "Status Salah"], 401);
$this->model->insert('tb_absensi_karyawan', ['nik' => $nik, "id_dinas" => $check_karyawan[0]->id_dinas, "tanggal" => $date, "jam_masuk" => $time]);
$this->response(['status' => true, 'message' => "Sukses Mengabsen"], 200);
}
// $this->response(['status' => true, 'message' => "Sukses Mengabsen", "data" => $date], 200);
}
public function get_perjalanan_dinas_libur_get() // ambil absensi ini hari berdasarkan kayawan
{
$nik = $this->get('nik');
$date = $this->get('date');
if ($nik == null || $nik == '' || $date == null || $date == '') return $this->response(['status' => false, 'message' => "Isi Semua Form"], 403);
$check_karyawan = $this->model->tampil_data_where('tb_karyawan', ['nik' => $nik])->result();
if (count($check_karyawan) == 0) return $this->response(['status' => false, 'message' => "Tiada Data"], 401);
$check_perjalanan_dinas = $this->model->tampil_data_where("tb_informasi_perjalanan_dinas", ["nik" => $nik, 'tanggal' => $date])->result();
if (count($check_perjalanan_dinas) > 0) {
$check_perjalanan_dinas = $check_perjalanan_dinas[0];
$check_perjalanan_dinas->stat = 'Perjalanan Dinas';
$this->response(['status' => true, 'message' => "Ada Perjalanan Dinas Karyawan", "data" => $check_perjalanan_dinas], 200);
}
$check_libur = $this->model->tampil_data_where("tb_informasi_libur", ["nik" => $nik, 'tanggal' => $date])->result();
if (count($check_libur) > 0) {
$check_libur = $check_libur[0];
$check_libur->stat = 'Libur';
$this->response(['status' => true, 'message' => "Ada Libur Karyawan", "data" => $check_libur], 200);
}
$this->response(['status' => true, 'message' => "Tiada Libur Karyawan", "data" => null], 200);
}
public function laporan_post()
{
$ada_foto = $this->post('ada_foto');
$nik = $this->post('nik');
$device_id = $this->post('device_id');
$id_dinas = $this->post('id_dinas');
$nama_laporan = $this->post('nama_laporan');
$ket_laporan = $this->post('ket_laporan');
$image = ($ada_foto == 'true') ? $_FILES['image'] : null;
if ($nik == null || $nik == '' || $ada_foto == null || $ada_foto == '' || $device_id == null || $device_id == '' || $id_dinas == null || $id_dinas == '' || $nama_laporan == null || $nama_laporan == '' || $ket_laporan == null || $ket_laporan == '') return $this->response(['status' => false, 'message' => "Isi Semua Form"], 403);
// cek user first
$cek_user = $this->model->tampil_data_where('tb_karyawan', ["nik" => $nik, "device_id" => $device_id, "id_dinas" => $id_dinas])->result();
if (count($cek_user) == 0) return $this->response(['status' => false, 'message' => "Karyawan, Device ID dan Dinas tidak cocok di sistem"], 401);
$auto_increment_val = $this->model->cek_last_ai('tb_laporan_karyawan');
$dir = "assets/images/karyawan/$auto_increment_val/";
$image_path = null;
if ($ada_foto == 'true') {
if (is_dir($dir) === false) {
mkdir($dir);
}
$path = $dir . $image['name'];
move_uploaded_file($image['tmp_name'], $path);
$image_path = $path;
}
// for ($i = 0; $i < 30; $i++) {
$this->model->insert('tb_laporan_karyawan', ['nik' => $nik, 'image' => $image_path, 'nama_laporan' => $nama_laporan, 'ket_laporan' => $ket_laporan, 'created_at' => date("Y-m-d H:i:s")]);
// }
$this->response(['status' => true, 'message' => 'Laporan Berhasil Ditambah'], 200);
}
public function laporan_get()
{
$nik = $this->get('nik');
$page = $this->get('page');
$where = $this->get('where');
$check_karyawan = $this->model->tampil_data_where('tb_karyawan', ['nik' => $nik])->result();
if (count($check_karyawan) == 0) return $this->response(['status' => false, 'message' => "Tiada Data"], 401);
$page_search = ($page - 1) * 10;
if ($where == '') {
$get_all_data = $this->model->custom_query("SELECT * FROM tb_laporan_karyawan where nik=$nik order by no_laporan desc")->result();
$cek_data = $this->model->custom_query("SELECT * FROM tb_laporan_karyawan where nik=$nik order by no_laporan desc limit 10 OFFSET $page_search ")->result();
} else {
$get_all_data = $this->model->custom_query("SELECT * FROM tb_laporan_karyawan where nik=$nik and ket_laporan like '%$where%' or nama_laporan like '%$where%' or created_at like '%$where%' order by no_laporan desc")->result();
$cek_data = $this->model->custom_query("SELECT * FROM tb_laporan_karyawan where nik=$nik and ket_laporan like '%$where%' or nama_laporan like '%$where%' or created_at like '%$where%' order by no_laporan desc limit 10 OFFSET $page_search ")->result();
}
$count_get_all_data = count($get_all_data);
$all_page = ceil($count_get_all_data / 10);
$data = ["count_all" => $count_get_all_data, "all_page" => $all_page, "data" => $cek_data];
$this->response(['status' => true, 'message' => "Selamat Login ", "data" => $data], 200);
}
public function my_location_post()
{
$nik = $this->post('nik');
$lat = $this->post('lat');
$lng = $this->post('lng');
if ($nik == null || $nik == '' || $lat == null || $lat == '' || $lng == null || $lng == '') return $this->response(['status' => false, 'message' => "Isi Semua Form"], 403);
$check_karyawan = $this->model->tampil_data_where('tb_karyawan', ['nik' => $nik])->result();
if (count($check_karyawan) == 0) return $this->response(['status' => false, 'message' => "Tiada Data"], 401);
$check_if_ada = $this->model->tampil_data_where('tb_kordinat_karyawan', ['nik' => $nik])->result();
$time = date("Y-m-d H:i:s");
if (count($check_if_ada) > 0) {
$this->model->update('tb_kordinat_karyawan', ['nik' => $nik], ['lat' => $lat, 'lng' => $lng, 'updated_at' => $time]);
} else {
$this->model->insert('tb_kordinat_karyawan', ['nik' => $nik],['lat' => $lat, 'lng' => $lng, 'updated_at' => $time]);
}
$this->response(['status' => true, 'message' => "ini dia"], 200);
}
}

View File

@ -5,7 +5,7 @@
<meta name="description" content="">
<meta name="author" content="">
<title>Sistem Kedisiplinan <?= $dinas ?> - <?= $header ?></title>
<title>Sistem Bantuan Sosial Tunai Dinas Sosial, Pariwisata dan Kebudayaan Pinrang - <?= $header ?></title>
<!-- Main Styles -->
<link rel="stylesheet" href="<?= base_url() ?>assets/styles/style.min.css">
@ -24,19 +24,6 @@
<!-- Sweet Alert -->
<link rel="stylesheet" href="<?= base_url() ?>assets/sweetalert/sweetalert.css">
<link rel="stylesheet" href="<?= base_url() ?>assets/toastr/toastr.min.css">
<link rel="apple-touch-icon" sizes="57x57" href="<?= base_url() ?>assets//images/favico/apple-icon-57x57.png">
<link rel="apple-touch-icon" sizes="60x60" href="<?= base_url() ?>assets//images/favico/apple-icon-60x60.png">
<link rel="apple-touch-icon" sizes="72x72" href="<?= base_url() ?>assets//images/favico/apple-icon-72x72.png">
<link rel="apple-touch-icon" sizes="76x76" href="<?= base_url() ?>assets//images/favico/apple-icon-76x76.png">
<link rel="apple-touch-icon" sizes="114x114" href="<?= base_url() ?>assets//images/favico/apple-icon-114x114.png">
<link rel="apple-touch-icon" sizes="120x120" href="<?= base_url() ?>assets//images/favico/apple-icon-120x120.png">
<link rel="apple-touch-icon" sizes="144x144" href="<?= base_url() ?>assets//images/favico/apple-icon-144x144.png">
<link rel="apple-touch-icon" sizes="152x152" href="<?= base_url() ?>assets//images/favico/apple-icon-152x152.png">
<link rel="apple-touch-icon" sizes="180x180" href="<?= base_url() ?>assets//images/favico/apple-icon-180x180.png">
<link rel="icon" type="image/png" sizes="192x192" href="<?= base_url() ?>assets/images/favico/android-icon-192x192.png">
<link rel="icon" type="image/png" sizes="32x32" href="<?= base_url() ?>assets/images/favico/favicon-32x32.png">
<link rel="icon" type="image/png" sizes="96x96" href="<?= base_url() ?>assets/images/favico/favicon-96x96.png">
<link rel="icon" type="image/png" sizes="16x16" href="<?= base_url() ?>assets/images/favico/<?= base_url() ?>assets/images/favico/favicon-16x16.png">
<style type="text/css">
.swal-modal .swal-text {
@ -44,10 +31,9 @@
}
</style>
<?php
if ($header == "Halaman Karyawan" || $header == "Halaman Jam Kerja" || $header == "Halaman Utama" || $header == "Halaman Pengaturan Libur" || $header == "Halaman Pengaturan Perjalanan Dinas" || $header == "Halaman Laporan") { ?>
<link rel="stylesheet" href="<?= base_url() ?>assets/plugin/datatables/media/css/dataTables.bootstrap.min.css">
<style>
<!-- <style>
.avatar {
vertical-align: middle;
width: 150px;
@ -55,16 +41,11 @@
border-radius: 50%;
}
</style>
<?php
}
?>
<?php
if ($header == "Halaman Pengaturan Libur" || $header == "Halaman Pengaturan Perjalanan Dinas") { ?>
<link rel="stylesheet" href="<?= base_url() ?>assets/plugin/select2/css/select2.min.css">
<link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/daterangepicker/daterangepicker.css" />
<?php
}
?>
<link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/daterangepicker/daterangepicker.css" /> -->
</head>

View File

@ -11,48 +11,32 @@
<div id="wrapper">
<div class="main-content">
<div class="row small-spacing">
<div class="col-xs-12">
<div class="box-content">
<h4 class="box-title" id="header_peta">Peta Absensi</h4>
<!-- /.dropdown js__dropdown -->
<div class="form-group">
<div id="map" style="width: 100%; height: 500px"></div>
</div>
<!-- /#flot-chart-1.flot-chart -->
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
<div class="col-xs-12">
<div class="box-content">
<h4 class="box-title" id="header_absensi">Absensi Karyawan</h4>
<div class="box-content card">
<h4 class="box-title" id="header_absensi">List Penduduk</h4>
<div class="card-content">
<!-- create button for 'Tambah Penduduk' -->
<button type="button" class="btn btn-primary btn-xs" onclick="tambah_penduduk()">
<i class="fa fa-plus"></i> Tambah Penduduk
</button>
<br /> <br />
<div style="overflow-x: auto">
<table id="table_list_karyawan" class="table table-striped table-bordered display" style="width:100%">
<table id="table_list_penduduk" class="table table-striped table-bordered display" style="width:100%">
<thead>
<tr>
<th>NIP</th>
<th>NIK</th>
<th>Nama</th>
<th>Status</th>
<th>Last Updated</th>
<th>Umur</th>
<th>No HP</th>
<th>Jenis Kelamin</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
<?php
foreach ($list_karyawan as $key => $value) {
?>
<tr>
<td><?=$value->nik?></td>
<td><?=$value->nama?></td>
<td id="status_<?=$value->nik?>"> <?=$value->status_kerja?> </td>
<td id="lu_<?=$value->nik?>"> - </td>
</tr>
<?php
}
?>
</tbody>
</table>
</div>
@ -71,177 +55,285 @@
<!-- /.main-content -->
</div>
<!-- create modal for 'Tambah Penduduk' -->
<div class="modal fade" id="modal_add_penduduk" tabindex="-1" role="dialog" aria-labelledby="modal_add_penduduk" aria-hidden="true">
<div class="modal-dialog modal-lg" role="document">
<div class="modal-content">
<div class="modal-header">
<h4 class="modal-title" id="modal_add_penduduk"></h4>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<form id="form_add_penduduk" onsubmit="return tambah_edit_penduduk(event)">
<div class="modal-body">
<div class="form-group">
<input type="hidden" id="status">
<label for="nik">NIK</label>
<input type="text" class="form-control" id="nik" name="nik" placeholder="Masukkan NIK" onkeypress="return isNumberKey(event)" minlength="16" maxlength="16" required>
</div>
<div class="form-group">
<label for="nama">Nama</label>
<input type="text" class="form-control" id="nama" name="nama" placeholder="Masukkan Nama" required>
</div>
<div class="form-group">
<label for="umur">Tanggal Lahir</label>
<input type="date" class="form-control" id="tgl_lahir" name="tgl_lahir" placeholder="Masukkan Tanggal Lahir" required>
</div>
<div class="form-group">
<label for="jenis_kelamin">Jenis Kelamin</label>
<select class="form-control" id="jenis_kelamin" name="jenis_kelamin" required>
<option value="">Pilih Jenis Kelamin</option>
<option value="Laki-laki">Laki-laki</option>
<option value="Perempuan">Perempuan</option>
</select>
</div>
<div class="form-group">
<label for="alamat">Alamat</label>
<textarea class="form-control" id="alamat" name="alamat" placeholder="Masukkan Alamat" style="resize :none;" required></textarea>
</div>
<div class="form-group">
<label for="no_hp">No HP</label>
<input type="text" class="form-control" id="no_hp" name="no_hp" placeholder="Masukkan No HP" onkeypress="return isNumberKey(event)" minlength="9" maxlength="13" required>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary btn-xs" data-dismiss="modal">Batal</button>
<button type="submit" class="btn btn-primary btn-xs" id="btn_add_penduduk">Simpan</button>
<button type="submit" class="btn btn-primary btn-xs" id="btn_update_penduduk">Update</button>
</div>
</form>
</div>
</div>
</div>
<?php $this->load->view('admin/scripts') ?>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/jquery.dataTables.min.js"></script>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/dataTables.bootstrap.min.js"></script>
<script src="https://maps.googleapis.com/maps/api/js?key=AIzaSyD7B9RynI4hQM_Y4BG9GYxsTLWwYkGASRo&libraries=geometry,drawing,places&v=weekly&region=ID&language=id"></script>
<script>
$('#table_list_karyawan').DataTable({
var data_lama;
})
var id_dinas = <?= $id_dinas ?>;
$("#header_peta").html(`Peta Absensi <i>(${getTodayDate()})</i>`)
$("#header_absensi").html(`Absensi Karyawan <i>(${getTodayDate()})</i>`)
function datatables() {
table = $('#table_list_penduduk').DataTable({
// "searching": false,
"lengthMenu": [
[5, 10, 15, -1],
[5, 10, 15, "All"]
],
"pageLength": 10,
"ordering": true,
"processing": true,
"serverSide": true,
// "order": [[ 4, 'desc' ]],
let markersOverlay = [];
"ajax": {
"url": server_url + "admin/",
"type": "POST",
data: {
proses: 'table_penduduk'
},
function addInfoWindow(marker, message) {
},
var infoWindow = new google.maps.InfoWindow({
content: message
});
google.maps.event.addListener(marker, 'click', function() {
infoWindow.open(map, marker);
"columnDefs": [{
"targets": [5],
"orderable": false,
}, ],
});
}
async function initMap() {
map = new google.maps.Map(document.getElementById("map"), {
zoom: 17.5,
center: {
lat: <?= $lat ?>,
lng: <?= $lng ?>
},
mapTypeId: 'hybrid',
streetViewControl: false,
});
datatables()
const cityCircle = new google.maps.Circle({
strokeColor: "#FF0000",
strokeOpacity: 0.3,
strokeWeight: 0.3,
fillColor: "#FF0000",
fillOpacity: 0.3,
map,
center: {
lat: <?= $lat ?>,
lng: <?= $lng ?>
},
radius: <?= $radius ?>,
});
function tambah_penduduk() {
// enable nik
$('#nik').prop('disabled', false);
// hide button update
$('#btn_update_penduduk').hide();
// show button simpan
$('#btn_add_penduduk').show();
// clear all input in modal
// status tambah
$('#status').val('tambah');
$('#form_add_penduduk').trigger('reset')
$('#modal_add_penduduk').modal('show')
$('#modal_add_penduduk').find('.modal-title').text('Tambah Penduduk')
const marker = new google.maps.Marker({
position: {
lat: <?= $lat ?>,
lng: <?= $lng ?>
},
map: map,
title: 'Center',
icon: 'https://maps.google.com/mapfiles/ms/icons/green-dot.png',
});
}
markersOverlay[0] = marker;
async function edit_penduduk(nik) {
// disable nik
$('#nik').attr('disabled', true)
// show button update
$('#btn_update_penduduk').show();
// hide button simpan
$('#btn_add_penduduk').hide();
// clear all input in modal
// status edit
$('#status').val('edit');
$('#form_add_penduduk').trigger('reset')
$('#modal_add_penduduk').modal('show')
$('#modal_add_penduduk').find('.modal-title').text('Edit Penduduk')
let dinas_html = `<div class="card-content">
<div class="form-group>
<label for="nik"><?= $dinas ?></label>
</div>
</div>`
addInfoWindow(marker, dinas_html);
setInterval(
async function() {
clearOverlays()
markers = []
markers = [{
lat: <?= $lat ?>,
lng: <?= $lng ?>
}]
let all_data;
let data;
try {
const the_data = await $.ajax({
url: server_url_api + "get_today_absensi?id_dinas=" + id_dinas,
data = await $.ajax({
url: server_url_api + "penduduk?nik=" + nik,
type: 'get',
async: false,
beforeSend: function(res) {
// block_ui("Mengambil Data Karyawan");
block_ui("Mengambil Data Penduduk");
},
});
// console.log(the_data);
all_data = the_data.data;
for (let i = 0; i < all_data.length; i++) {
markers.push(all_data[i])
// console.log(all_data)
data = data.data
data_lama = data
console.log(data)
$('#nik').val(data.nik)
$('#nama').val(data.nama)
$('#tgl_lahir').val(data.tgl_lahir)
$('#jenis_kelamin').val(data.jenis_kelamin)
$('#alamat').val(data.alamat)
$('#no_hp').val(data.no_hp)
await $.unblockUI();
} catch (error) {
await $.unblockUI();
const statusCode = error.status;
console.log(error)
console.log(statusCode)
if (statusCode == 0 || statusCode == 500) return toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
const message = error.responseJSON.message
toastr.error(message);
}
let arr = []
for (let i = 0; i < markers.length; i++) {
console.log(markers[i]['lat'])
let latlng = new google.maps.LatLng(markers[i]['lat'], markers[i]['lng']);
arr.push(latlng);
let color = i > 0 ? 'blue' : 'green'
}
const marker = new google.maps.Marker({
position: {
lat: markers[i]['lat'],
lng: markers[i]['lng']
// tambah_edit_penduduk
function tambah_edit_penduduk(e) {
e.preventDefault();
const status = $('#status').val();
const nik = $('#nik').val();
const nama = $('#nama').val();
const tgl_lahir = $('#tgl_lahir').val();
const jenis_kelamin = $('#jenis_kelamin').val();
const alamat = $('#alamat').val();
const no_hp = $('#no_hp').val();
console.log(status, nik, nama, tgl_lahir, jenis_kelamin, alamat, no_hp);
if (status == 'edit') {
const data = {
nik: nik,
nama: nama,
tgl_lahir: tgl_lahir,
jenis_kelamin: jenis_kelamin,
alamat: alamat,
no_hp: no_hp,
}
if (JSON.stringify(data) === JSON.stringify(data_lama)) {
return toastr.warning("Data tidak ada yang berubah");
}
}
// show swal before submit
swal({
title: "Apakah anda yakin?",
text: "Data akan "+ ( status == 'tambah' ? 'ditambahkan' : 'diubah' ) +"!",
icon: "info",
buttons: true,
dangerMode: false,
}).then((willDelete) => {
if (willDelete) {
$.ajax({
type: status == 'tambah' ? 'post' : 'put',
url: server_url_api + "penduduk",
data: {
nik: nik,
nama: nama,
tgl_lahir: tgl_lahir,
jenis_kelamin: jenis_kelamin,
alamat: alamat,
no_hp: no_hp
},
map: map,
title: 'Center',
icon: `https://maps.google.com/mapfiles/ms/icons/${color}-dot.png`,
});
dataType: "JSON",
beforeSend: function(res) {
block_ui("Menyimpan Data Penduduk");
},
success: function(response) {
markersOverlay[i] = marker;
if (i > 0) {
let html = `<div class="card-content">
<div class="form-group>
<label for="nik">NIK</label>
<input type="text" class="form-control" value="${markers[i]['nik']}" disabled>
</div>
<div class="form-group>
<label for="nik">Nama</label>
<input type="text" class="form-control" value="${markers[i]['nama']}" disabled>
</div>
<div class="form-group>
<label for="nik">Last Updated</label>
<input type="text" class="form-control" value="${markers[i]['last_updated']}" disabled>
</div>
<div class="form-group>
<label for="nik">Status</label>
<input type="text" class="form-control" value="${markers[i]['status']}" disabled>
</div>
</div>`
$("#lu_"+markers[i]['nik']).html(markers[i]['last_updated']);
$("#status_"+markers[i]['nik']).html(markers[i]['status']);
addInfoWindow(marker, html);
// close modal
$('#modal_add_penduduk').modal('hide')
$('#table_list_penduduk').dataTable().fnDestroy();
datatables();
toastr.success(response.message)
$.unblockUI();
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
const statusCode = XMLHttpRequest.status;
const responseJSON = XMLHttpRequest.responseJSON;
console.log(statusCode);
console.log(responseJSON)
if (statusCode != 500 || statusCode != 0) {
toastr.error(responseJSON.message);
} else {
addInfoWindow(marker, dinas_html);
toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
}
$.unblockUI();
}
var bounds = new google.maps.LatLngBounds();
if (markers.length > 1) {
for (var i = 0; i < arr.length; i++) {
bounds.extend(arr[i]);
});
}
map.fitBounds(bounds);
});
}
} catch (e) {
console.log(e)
function hapus_penduduk(id) {
swal({
title: "Apakah anda yakin?",
text: "Data akan dihapus!",
icon: "warning",
buttons: true,
dangerMode: true,
}).then((willDelete) => {
if (willDelete) {
$.ajax({
type: 'delete',
url: server_url_api + "penduduk/",
data : {
nik : id
},
dataType: "JSON",
beforeSend: function(res) {
block_ui("Menghapus Data Penduduk");
},
success: function(response) {
console.log(response)
$('#table_list_penduduk').dataTable().fnDestroy();
datatables();
toastr.success(response.message)
$.unblockUI();
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
const statusCode = XMLHttpRequest.status;
const responseJSON = XMLHttpRequest.responseJSON;
console.log(statusCode);
console.log(responseJSON)
if (statusCode != 500 || statusCode != 0) {
toastr.error(responseJSON.message);
} else {
toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
}
}, 5000)
}
google.maps.event.addDomListener(window, 'load', initMap);
function clearOverlays() {
if (markersOverlay) {
for (i in markersOverlay) {
markersOverlay[i].setMap(null);
$.unblockUI();
}
});
}
});
}
</script>

View File

@ -1,298 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<?php $this->load->view("admin/header"); ?>
<body>
<?php $this->load->view("admin/side_topbar"); ?>
<div id="wrapper">
<div class="main-content">
<div class="row small-spacing">
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title">List Hari Jam Kerja</h4>
<!-- /.dropdown js__dropdown -->
<div class="card-content">
<div style="overflow-x: auto">
<table id="table_list_hari" class="table table-striped table-bordered display" style="width:100%">
<thead>
<tr>
<th>Hari</th>
<th>Jam Masuk</th>
<th>Jam Istirehat</th>
<th>Jam Masuk Kembali</th>
<th>Jam Pulang</th>
<th>Aksi</th>
</tr>
</thead>
<tbody style="text-align: center;">
<tr id="senin">
<td class="harinya">Senin</td>
<td class="jam_masuk">-</td>
<td class="jam_istirehat">-</td>
<td class="jam_masuk_kembali">-</td>
<td class="jam_pulang">-</td>
<td><button type='button' onclick="edit_hari_kerja('senin')" title='Edit Detail Karyawan' class='btn btn-primary btn-circle btn-sm waves-effect waves-light'><i class='ico fa fa-edit'></i></button></td>
</tr>
<tr id="selasa">
<td class="harinya">Selasa</td>
<td class="jam_masuk">-</td>
<td class="jam_istirehat">-</td>
<td class="jam_masuk_kembali">-</td>
<td class="jam_pulang">-</td>
<td><button type='button' onclick="edit_hari_kerja('selasa')" title='Edit Detail Karyawan' class='btn btn-primary btn-circle btn-sm waves-effect waves-light'><i class='ico fa fa-edit'></i></button></td>
</tr>
<tr id="rabu">
<td class="harinya">Rabu</td>
<td class="jam_masuk">-</td>
<td class="jam_istirehat">-</td>
<td class="jam_masuk_kembali">-</td>
<td class="jam_pulang">-</td>
<td><button type='button' onclick="edit_hari_kerja('rabu')" title='Edit Detail Karyawan' class='btn btn-primary btn-circle btn-sm waves-effect waves-light'><i class='ico fa fa-edit'></i></button></td>
</tr>
<tr id="kamis">
<td class="harinya">Kamis</td>
<td class="jam_masuk">-</td>
<td class="jam_istirehat">-</td>
<td class="jam_masuk_kembali">-</td>
<td class="jam_pulang">-</td>
<td><button type='button' onclick="edit_hari_kerja('kamis')" title='Edit Detail Karyawan' class='btn btn-primary btn-circle btn-sm waves-effect waves-light'><i class='ico fa fa-edit'></i></button></td>
</tr>
<tr id="jumat">
<td class="harinya">Jumat</td>
<td class="jam_masuk">-</td>
<td class="jam_istirehat">-</td>
<td class="jam_masuk_kembali">-</td>
<td class="jam_pulang">-</td>
<td><button type='button' onclick="edit_hari_kerja('jumat')" title='Edit Detail Karyawan' class='btn btn-primary btn-circle btn-sm waves-effect waves-light'><i class='ico fa fa-edit'></i></button></td>
</tr>
<tr id="sabtu">
<td class="harinya">Sabtu</td>
<td class="jam_masuk">-</td>
<td class="jam_istirehat">-</td>
<td class="jam_masuk_kembali">-</td>
<td class="jam_pulang">-</td>
<td><button type='button' onclick="edit_hari_kerja('sabtu')" title='Edit Detail Karyawan' class='btn btn-primary btn-circle btn-sm waves-effect waves-light'><i class='ico fa fa-edit'></i></button></td>
</tr>
<tr id="ahad">
<td class="harinya">Ahad</td>
<td class="jam_masuk">-</td>
<td class="jam_istirehat">-</td>
<td class="jam_masuk_kembali">-</td>
<td class="jam_pulang">-</td>
<td><button type='button' onclick="edit_hari_kerja('ahad')" title='Edit Detail Karyawan' class='btn btn-primary btn-circle btn-sm waves-effect waves-light'><i class='ico fa fa-edit'></i></button></td>
</tr>
</tbody>
</table>
</div>
<br>
</div>
<!-- /#flot-chart-1.flot-chart -->
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<!-- /.row -->
<?php $this->load->view('admin/footer') ?>
</div>
<!-- /.main-content -->
</div>
<div class="modal fade" id="modal_jam_kerja" tabindex="-1" role="dialog" aria-labelledby="myModalLabel-1" data-keyboard="false" data-backdrop="static">
<div class="modal-dialog modal-lg" role="document">
<form class="modal-content" onsubmit="return edit_jam_kerja(event)">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
<h4 class="modal-title" id="myModalLabel-1"></h4>
<!-- <p style="font-size: 10px;"><i>(Geserkan marker ke titik kordinat dinas)</i></p> -->
</div>
<div class="modal-body">
<div class="form-group">
<label for="nik">Jam Masuk</label>
<input type="hidden" id="hari">
<input type="time" class="form-control" id="jam_masuk" required>
</div>
<div class="form-group">
<label for="nik">Jam Istirehat</label>
<input type="time" class="form-control" id="jam_istirehat" required>
</div>
<div class="form-group">
<label for="nik">Jam Masuk Kembali</label>
<input type="time" class="form-control" id="jam_masuk_kembali" required>
</div>
<div class="form-group">
<label for="nik">Jam Pulang</label>
<input type="time" class="form-control" id="jam_pulang" required>
</div>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary btn-xs waves-effect waves-light">Simpan Perubahan</button>
<button type="button" class="btn btn-danger btn-xs waves-effect waves-light" data-dismiss="modal">Batalkan</button>
</div>
</form>
</div>
</div>
<?php $this->load->view('admin/scripts') ?>
<!-- <script src="<?= base_url() ?>assets/plugin/datatables/media/js/jquery.dataTables.min.js"></script>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/dataTables.bootstrap.min.js"></script> -->
<script>
var id_dinas = <?= $id_dinas ?>;
var all_data = [];
async function get_all_data() {
let data;
try {
data = await $.ajax({
url: server_url_api + "jam_kerja?id_dinas=" + id_dinas,
type: 'get',
async: false,
beforeSend: function(res) {
block_ui("Mengambil Data Jam Kerja");
},
});
data = data.data
all_data = data
data.forEach((item, index) => {
$("#table_list_hari #" + item['hari'] + " .jam_masuk").html(tConvert(item['jam_masuk']))
$("#table_list_hari #" + item['hari'] + " .jam_istirehat").html(tConvert(item['jam_istirehat']))
$("#table_list_hari #" + item['hari'] + " .jam_masuk_kembali").html(tConvert(item['jam_masuk_kembali']))
$("#table_list_hari #" + item['hari'] + " .jam_pulang").html(tConvert(item['jam_pulang']))
})
// data_karyawan = data;
await $.unblockUI();
} catch (error) {
await $.unblockUI();
const statusCode = error.status;
console.log(error)
console.log(statusCode)
if (statusCode == 0 || statusCode == 500) return toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
const message = error.responseJSON.message
toastr.error(message);
}
}
get_all_data();
function edit_hari_kerja(hari) {
// console.log(all_data)
$("#hari").val(null)
$("#jam_masuk").val(null)
$("#jam_istirehat").val(null)
$("#jam_masuk_kembali").val(null)
$("#jam_pulang").val(null)
all_data.forEach((item, index) => {
if (item['hari'] == hari) {
const jam_masuk = $("#jam_masuk").val(item['jam_masuk'])
const jam_istirehat = $("#jam_istirehat").val(item['jam_istirehat'])
const jam_masuk_kembali = $("#jam_masuk_kembali").val(item['jam_masuk_kembali'])
const jam_pulang = $("#jam_pulang").val(item['jam_pulang'])
}
})
$(".modal .modal-title").html(`Jam Kerja Hari ${uppercaseWord(hari)}`)
$("#hari").val(hari)
$('#modal_jam_kerja').modal('show');
console.log(hari)
}
function edit_jam_kerja(e) {
e.preventDefault()
const hari = $("#hari").val()
const jam_masuk = $("#jam_masuk").val()
const jam_istirehat = $("#jam_istirehat").val()
const jam_masuk_kembali = $("#jam_masuk_kembali").val()
const jam_pulang = $("#jam_pulang").val()
if (jam_masuk >= jam_istirehat && jam_masuk >= jam_masuk_kembali && jam_masuk >= jam_pulang) return toastr.error("Jam Karja Harus Berurutan Dari Jam Masuk Sampai Jam Pulang Dan Tidak Bisa Sama");
if (jam_istirehat >= jam_masuk_kembali && jam_istirehat >= jam_pulang) return toastr.error("Jam Karja Harus Berurutan Dari Jam Masuk Sampai Jam Pulang Dan Tidak Bisa Sama");
if (jam_masuk_kembali >= jam_pulang) return toastr.error("Jam Karja Harus Berurutan Dari Jam Masuk Sampai Jam Pulang Dan Tidak Bisa Sama");
let cari_data = null;
for (const data of all_data) {
if (data['hari'] == hari) {
cari_data = data;
}
}
if (cari_data != null) {
if (cari_data['jam_masuk'] == jam_masuk && cari_data['jam_istirehat'] == jam_istirehat && cari_data['jam_masuk_kembali'] == jam_masuk_kembali && cari_data['jam_pulang'] == jam_pulang) return toastr.error("Tiada Perubahan Data Yang Dilakukan");
}
swal({
text: `Edit Jam Kerja\nHari ${hari} ?`,
icon: "info",
buttons: {
cancel: true,
confirm: true,
},
// dangerMode: true,
}).then((yes) => {
if (yes) {
// console.log("tambah karyawan",nik,nama,jabatan,alamat)
$.ajax({
url: server_url_api + "jam_kerja",
type: 'post',
data: {
id_dinas: id_dinas,
hari: hari,
jam_masuk: jam_masuk,
jam_istirehat: jam_istirehat,
jam_masuk_kembali: jam_masuk_kembali,
jam_pulang: jam_pulang,
},
beforeSend: function(res) {
$('#modal_jam_kerja').modal('hide');
block_ui("Menyimpan Perunahan Jam Kerja");
},
success: function(response) {
$.unblockUI();
// window.location.reload();
console.log(response)
get_all_data()
// $('#table_list_karyawan').dataTable().fnDestroy();
// datatables()
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
$.unblockUI();
// console.log(errorThrown)
// console.log(textStatus)
const statusCode = XMLHttpRequest.status;
const responseJSON = XMLHttpRequest.responseJSON;
console.log(statusCode);
console.log(responseJSON)
if (statusCode != 500 || statusCode != 0) {
toastr.error(responseJSON.message);
} else {
toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
}
}
});
}
});
// console.log("sini edit jam kerja");
}
</script>
</body>
<!-- Dibuat oleh Kicap Karan. https://www.kicap-karan.com -->
</html>

View File

@ -1,451 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<?php $this->load->view("admin/header"); ?>
<body>
<?php $this->load->view("admin/side_topbar"); ?>
<div id="wrapper">
<div class="main-content">
<div class="row small-spacing">
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title">List Karyawan </h4>
<!-- /.dropdown js__dropdown -->
<div class="card-content">
<div style="overflow-x: auto">
<table id="table_list_karyawan" class="table table-striped table-bordered display" style="width:100%">
<thead>
<tr>
<th>No</th>
<th>NIP</th>
<th>Nama</th>
<th>No Telpon</th>
<th>Jabatan</th>
<th>Pangkat</th>
<th>Aksi</th>
</tr>
</thead>
</table>
</div>
<br>
<div class="form-group text-center">
<button type="button" class="btn btn-primary btn-sm waves-effect waves-light" onclick="buka_modal_tambah()">Tambah Karyawan</button>
</div>
</div>
<!-- /#flot-chart-1.flot-chart -->
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<!-- /.row -->
<?php $this->load->view('admin/footer') ?>
</div>
<!-- /.main-content -->
</div>
<div class="modal fade" id="modal_karyawan" tabindex="-1" role="dialog" aria-labelledby="myModalLabel-1" data-keyboard="false" data-backdrop="static">
<div class="modal-dialog modal-lg" role="document">
<form class="modal-content" onsubmit="return tambah_edit(event)">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
<h4 class="modal-title" id="myModalLabel-1"></h4>
<!-- <p style="font-size: 10px;"><i>(Geserkan marker ke titik kordinat dinas)</i></p> -->
</div>
<div class="modal-body">
<div class="form-group text-center" id="div_img" style="display: none;">
<img src="" class="avatar" id="img_container" />
</div>
<div class="form-group">
<label for="nik">Foto</label>
<input type="file" class="form-control" id="foto" required="true">
</div>
<div class="form-group">
<label for="nik">NIP Karyawan</label>
<input type="hidden" id="status_form">
<input type="text" class="form-control" id="nik" placeholder="Masukkan NIK Karyawan" minlength="16" maxlength="16" onkeypress="return isNumberKey(event)" required>
</div>
<div class="form-group">
<label for="nama">Nama</label>
<input type="text" class="form-control" id="nama" placeholder="Masukkan Nama Karyawan" required>
</div>
<div class="form-group">
<label for="nama">No Telepon</label>
<input type="text" class="form-control" id="no_telpon" placeholder="Masukkan No Telepon Karyawan" minlength="11" maxlength="13" onkeypress="return isNumberKey(event)" required>
</div>
<div class="form-group">
<label for="jabatan">Jabatan</label>
<input type="text" class="form-control" id="jabatan" placeholder="Masukkan Jabatan Karyawan" required>
</div>
<div class="form-group">
<label for="pangkat">Pangkat</label>
<select name="pangkat" id="pangkat" class="form-control" required>
<option value="" disabled selected>-Pilih Pangkat</option>
<option value="Tiada">Tiada</option>
<option value="I A">I A</option>
<option value="I B">I B</option>
<option value="I C">I C</option>
<option value="I D">I D</option>
<option value="II A">II A</option>
<option value="II B">II B</option>
<option value="II C">II C</option>
<option value="II D">II D</option>
<option value="III A">III A</option>
<option value="III B">III B</option>
<option value="III C">III C</option>
<option value="III D">III D</option>
<option value="IV A">IV A</option>
<option value="IV B">IV B</option>
<option value="IV C">IV C</option>
<option value="IV D">IV D</option>
</select>
</div>
<div class="form-group">
<label for="status">Status</label>
<select name="status" id="status" class="form-control" required>
<option value="" disabled selected>-Pilih Status</option>
<option value="PNS" >PNS</option>
<option value="Kontrak" >Kontrak</option>
</select>
</div>
<div class="form-group">
<label for="tanggal_lahir">Tanggal Lahir</label>
<input type="date" class="form-control" id="tanggal_lahir" required>
</div>
<div class="form-group">
<label for="alamat">Alamat</label>
<textarea name="alamat" id="alamat" cols="30" rows="10" class="form-control" style="resize: none;" placeholder="Masukkan Alamat" required></textarea>
</div>
</div>
<div class="modal-footer">
<button type="submit" id="button_simpan_edit" class="btn btn-primary btn-xs waves-effect waves-light"></button>
<button type="button" class="btn btn-danger btn-xs waves-effect waves-light" data-dismiss="modal">Batalkan</button>
</div>
</form>
</div>
</div>
<?php $this->load->view('admin/scripts') ?>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/jquery.dataTables.min.js"></script>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/dataTables.bootstrap.min.js"></script>
<script async>
var id_dinas = <?= $id_dinas ?>;
var data_karyawan;
var table;
function datatables() {
table = $('#table_list_karyawan').DataTable({
// "searching": false,
"lengthMenu": [
[5, 10, 15, -1],
[5, 10, 15, "All"]
],
"pageLength": 10,
"ordering": true,
"processing": true,
"serverSide": true,
// "order": [[ 4, 'desc' ]],
"ajax": {
"url": server_url + "admin/karyawan",
"type": "POST",
data: {
proses: 'table_karyawan'
},
},
"columnDefs": [{
"targets": [0],
"orderable": false,
}, ],
});
}
datatables()
document.getElementById("foto").onchange = function() {
let foto_produk = document.getElementById('foto').files[0];
check_file(foto_produk)
}
function buka_modal_tambah() { // buka modal untuk tambah karyawan
$(".modal-title").html("Form Tambah Karyawan")
$("#status_form").val("tambah")
$("#button_simpan_edit").html("Tambah Karyawan")
$("#nik").val(null)
$("#foto").val(null)
$("#nama").val(null)
$("#no_telpon").val(null)
$("#jabatan").val(null)
$("#alamat").html(null)
$("#tanggal_lahir").val(null)
$("#nik").attr("disabled", false)
$("#foto").attr('required', true)
$("#div_img").attr('style', "display : none")
selectElement('pangkat', '');
selectElement('status', '');
$('#modal_karyawan').modal('show');
}
async function karyawan_edit(nik) {
// console.log(nik);
$(".modal-title").html("Form Edit Karyawan")
$("#status_form").val("edit")
$("#button_simpan_edit").html("Edit Karyawan")
$("#foto").attr('required', false)
$("#foto").val(null)
$("#div_img").removeAttr("style")
let data;
try {
data = await $.ajax({
url: server_url_api + "karyawan?nik=" + nik + "&id_dinas=" + id_dinas,
type: 'get',
async: false,
beforeSend: function(res) {
block_ui("Mengambil Data Karyawan");
},
});
data = data.data
data_karyawan = data;
await $.unblockUI();
$("#nik").val(data.nik)
$("#nama").val(data.nama)
$("#no_telpon").val(data.no_telpon)
$("#jabatan").val(data.jabatan)
$("#tanggal_lahir").val(data.tanggal_lahir)
$("#alamat").html(data.alamat)
$("#nik").attr("disabled", true)
$("#img_container").attr("src", server_url + data.image)
selectElement('pangkat', data.pangkat);
selectElement('status', data.status);
$('#modal_karyawan').modal('show');
} catch (error) {
await $.unblockUI();
const statusCode = error.status;
console.log(error)
console.log(statusCode)
if (statusCode == 0 || statusCode == 500) return toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
const message = error.responseJSON.message
toastr.error(message);
}
}
function tambah_edit(e) {
e.preventDefault();
const status_form = $("#status_form").val()
const foto = document.getElementById('foto').files[0]
const nik = $("#nik").val()
const nama = $("#nama").val()
const no_telpon = $("#no_telpon").val()
const jabatan = $("#jabatan").val()
const alamat = $("#alamat").val()
const pangkat = $("#pangkat").val()
const status = $("#status").val()
const tanggal_lahir = $("#tanggal_lahir").val()
// console.log(pangkat,status,tanggal_lahir)
let data = new FormData()
data.append('nik', nik)
data.append('proses', status)
data.append('foto', foto == undefined ? 'tiada' : foto)
data.append('nama', nama)
data.append('no_telpon', no_telpon)
data.append('jabatan', jabatan)
data.append('alamat', alamat)
data.append('id_dinas', id_dinas)
data.append('status_form', status_form)
data.append('pangkat', pangkat)
data.append('status', status)
data.append('tanggal_lahir', tanggal_lahir)
if (status_form == "tambah") {
swal({
text: `Tambah Karyawan Dengan\nNIK : ${nik},\nNama : ${nama}`,
icon: "info",
buttons: {
cancel: true,
confirm: true,
},
// dangerMode: true,
}).then((yes) => {
if (yes) {
// console.log("tambah karyawan", nik, nama, jabatan, alamat)
$.ajax({
url: server_url_api + "karyawan",
type: 'post',
contentType: false,
processData: false,
data,
beforeSend: function(res) {
$('#modal_karyawan').modal('hide');
block_ui("Menambah Karyawan");
},
success: function(response) {
$.unblockUI();
// window.location.reload();
console.log(response)
$('#table_list_karyawan').dataTable().fnDestroy();
datatables()
toastr.success(response.message);
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
$.unblockUI();
// console.log(errorThrown)
// console.log(textStatus)
const statusCode = XMLHttpRequest.status;
const responseJSON = XMLHttpRequest.responseJSON;
console.log(statusCode);
console.log(responseJSON)
if (statusCode != 500 || statusCode != 0) {
toastr.error(responseJSON.message);
} else {
toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
}
}
});
}
});
}
if (status_form == 'edit') {
// console.log(nik,nama,no_telpon,jabatan,alamat)
// if (nik == data_karyawan.nik && nama == data_karyawan.nama && no_telpon == data_karyawan.no_telpon && jabatan == data_karyawan.jabatan && alamat == data_karyawan.alamat) return toastr.warning("Tiada Perubahan Data Karyawan");
// console.log("sini berlaku edit")
swal({
text: `Edit Data Karyawan ?`,
icon: "info",
buttons: {
cancel: true,
confirm: true,
},
// dangerMode: true,
}).then((yes) => {
if (yes) {
// console.log("tambah karyawan",nik,nama,jabatan,alamat)
$.ajax({
url: server_url_api + "karyawan",
type: 'post',
contentType: false,
processData: false,
data,
beforeSend: function(res) {
$('#modal_karyawan').modal('hide');
block_ui("Edit Data Karyawan");
},
success: function(response) {
$.unblockUI();
// window.location.reload();
$('#table_list_karyawan').dataTable().fnDestroy();
datatables()
// console.log(response)
toastr.success(response.message);
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
$.unblockUI();
// console.log(errorThrown)
// console.log(textStatus)
const statusCode = XMLHttpRequest.status;
const responseJSON = XMLHttpRequest.responseJSON;
console.log(statusCode);
console.log(responseJSON)
if (statusCode != 500 || statusCode != 0) {
toastr.error(responseJSON.message);
} else {
toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
}
}
});
}
});
}
// console.log("sini tambah atau edit", status)
}
function hapus_karyawan(nik) {
// console.log(nik)
swal({
text: `Hapus Data Karyawan Dengan\nNIK : ${nik}\n?`,
icon: "warning",
dangerMode: true,
buttons: {
cancel: true,
confirm: true,
},
// dangerMode: true,
}).then((yes) => {
if (yes) {
// console.log("hapus karyawan")
$.ajax({
url: server_url_api + "karyawan",
type: 'delete',
data: {
id_dinas: id_dinas,
nik: nik,
},
beforeSend: function(res) {
$('#modal_karyawan').modal('hide');
block_ui("Hapus Karyawan");
},
success: function(response) {
$.unblockUI();
// window.location.reload();
$('#table_list_karyawan').dataTable().fnDestroy();
datatables()
console.log(response)
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
$.unblockUI();
// console.log(errorThrown)
// console.log(textStatus)
const statusCode = XMLHttpRequest.status;
const responseJSON = XMLHttpRequest.responseJSON;
console.log(statusCode);
console.log(responseJSON)
if (statusCode != 500 || statusCode != 0) {
toastr.error(responseJSON.message);
} else {
toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
}
}
});
}
});
}
</script>
</body>
<!-- Dibuat oleh Kicap Karan. https://www.kicap-karan.com -->
</html>

View File

@ -1,221 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<?php $this->load->view("admin/header"); ?>
<body>
<?php $this->load->view("admin/side_topbar"); ?>
<div id="wrapper">
<div class="main-content">
<div class="row small-spacing">
<div class="col-xs-2"></div>
<div class="col-xs-8">
<div class="box-content card">
<h4 class="box-title">Filter Laporan </h4>
<!-- /.dropdown js__dropdown -->
<!-- /#flot-chart-1.flot-chart -->
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
<div class="col-xs-2"></div>
</div>
<div class="row small-spacing">
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title">Laporan Absensi Bulan <?= $month ?>, Tahun <?= $year ?></h4>
<div class="card-content">
<div style="overflow-x: auto;" class="form-group">
<table id="example" class="table table-striped table-bordered display" style="width:100%">
<thead>
<tr>
<th>Nama / NIP</th>
<th>Jabatan</th>
<th>Tanggal</th>
<th>Status</th>
<th>Jam Masuk</th>
<th>Jam Istirehat</th>
<th>Jam Masuk Kembali</th>
<th>Jam Pulang</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
<?php
for ($i = $first_date; $i <= $last_date; $i++) {
foreach ($list_karyawan as $key => $value) {
$tanggal = strlen($i) == 1 ? "0" . $i : $i;
// echo
$CI = &get_instance();
$CI->load->model('model');
$check_absensi = $CI->model->tampil_data_where('tb_absensi_karyawan', ['nik' => $value->nik, "tanggal" => $year . "-" . $month . "-" . $tanggal])->result();
$status = '-';
$jam_masuk = "-";
$jam_istirehat = "-";
$jam_masuk_kembali = "-";
$jam_pulang = "-";
if (count($check_absensi) > 0) {
$status = 'Masuk Kerja';
$jam_masuk = $check_absensi[0]->jam_masuk;
$jam_istirehat = $check_absensi[0]->jam_istirehat ?? '-';
$jam_masuk_kembali = $check_absensi[0]->jam_masuk_kembali ?? '-';
$jam_pulang = $check_absensi[0]->jam_pulang ?? '-';
}
$check_libur = $CI->model->tampil_data_where('tb_informasi_libur', ['nik' => $value->nik, "tanggal" => $year . "-" . $month . "-" . $tanggal])->result();
if (count($check_libur) > 0) {
$status = "Libur";
$idnya = $check_libur[0]->id_libur;
}
$check_perjalanan_dinas = $CI->model->tampil_data_where('tb_informasi_perjalanan_dinas', ['nik' => $value->nik, "tanggal" => $year . "-" . $month . "-" . $tanggal])->result();
if (count($check_perjalanan_dinas) > 0) {
$status = "Perjalanan Dinas";
$idnya = $check_perjalanan_dinas[0]->id_perjalanan_dinas;
}
?>
<tr>
<td><?= $value->nama ?> / <?= $value->nik ?> </td>
<td><?= $value->jabatan ?></td>
<td><?= $tanggal ?>-<?= $month ?>-<?= $year ?></td>
<td><?= $status ?></td>
<td><?= $jam_masuk ?></td>
<td><?= $jam_istirehat ?></td>
<td><?= $jam_masuk_kembali ?></td>
<td><?= $jam_pulang ?></td>
<td>
<?php
if ($status == 'Libur' || $status == "Perjalanan Dinas") {
?>
<center><button type='button' onclick='check_info("<?= $status ?>" ,<?= $idnya ?>)' title='Check Informasi <?= $status ?>' class='btn btn-primary btn-circle btn-sm waves-effect waves-light'><i class='ico zmdi zmdi-info-outline'></i></button></center>
<?php
} else {
echo "-";
}
?>
</td>
</tr>
<?php
}
}
?>
</tbody>
</table>
</div>
<div class="form-group text-center">
<div id="iframeDisplay"></div>
<button type="button" id="button_cetak" class="btn btn-primary btn-xs waves-effect waves-light" onclick="displayIframe()">Cetak Laporan</button>
</div>
</div>
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<!-- /.row -->
<?php $this->load->view('admin/footer') ?>
</div>
<!-- /.main-content -->
</div>
<div class="modal fade" id="modal_pdf" tabindex="-1" role="dialog" aria-labelledby="myModalLabel-1" data-keyboard="false">
<div class="modal-dialog modal-lg" role="document" >
<div class="modal-content">
</div>
</div>
</div>
<?php $this->load->view('admin/scripts') ?>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/jquery.dataTables.min.js"></script>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/dataTables.bootstrap.min.js"></script>
<script>
$(document).ready(function() {
var groupColumn = 2;
var table = $('#example').DataTable({
columnDefs: [{
visible: false,
targets: groupColumn
}],
order: [
[groupColumn, 'asc']
],
displayLength: 25,
drawCallback: function(settings) {
var api = this.api();
var rows = api.rows({
page: 'current'
}).nodes();
var last = null;
api
.column(groupColumn, {
page: 'current'
})
.data()
.each(function(group, i) {
if (last !== group) {
$(rows)
.eq(i)
.before('<tr class="group text-center"><td colspan="8">' + group + '</td></tr>');
last = group;
}
});
},
});
// Order by the grouping
$('#example tbody').on('click', 'tr.group', function() {
var currentOrder = table.order()[0];
if (currentOrder[0] === groupColumn && currentOrder[1] === 'asc') {
table.order([groupColumn, 'desc']).draw();
} else {
table.order([groupColumn, 'asc']).draw();
}
});
});
</script>
<script>
async function check_info(stat, id) {
console.log(stat, id)
}
function displayIframe() {
document.getElementById("iframeDisplay").innerHTML = "<iframe src=\"../HtmlPage1.html\" height=\"200\" width=\"300\" ></iframe>";
}
</script>
</body>
<!-- Dibuat oleh Kicap Karan. https://www.kicap-karan.com -->
</html>

View File

@ -1,354 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<?php $this->load->view("admin/header"); ?>
<body>
<?php $this->load->view("admin/side_topbar"); ?>
<div id="wrapper">
<div class="main-content">
<div class="row small-spacing">
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title">Form Libur </h4>
<form class="card-content" onsubmit="return tambah_libur(event)">
<div class="form-group">
<label for="tanggal_libur">Range Tanggal</label>
<input type="text" name="tanggal_libur" class="form-control" value="" reqruied />
</div>
<div class="form-group">
<label for="tanggal_libur">List Karyawan</label>
<div class="row small-spacing" style="overflow-x: auto;">
<div class="col-xs-9">
<select multiple id="select_list_karyawan" class="form-control" onchange="check_dulu()" required>
</select>
</div>
<div class="col-xs-3">
<li class="checkbox">
<input type="checkbox" id="chk-2"><label for="chk-2">Semua</label>
</li>
</div>
</div>
</div>
<div class="form-group">
<label for="tanggal_libur">Keterangan</label>
<textarea name="" id="ket" cols="30" rows="10" class="form-control" style="resize: none" placeholder="Keterangan Libur" required></textarea>
</div>
<div class="form-group text-center">
<button type="submit" class="btn btn-primary btn-xs waves-effect waves-light">
Tambah Libur
</button>
</div>
</form>
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<div class="row small-spacing">
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title">List Libur</h4>
<div class="card-content">
<div style="overflow-x: auto">
<table id="table_list_libur" class="table table-striped table-bordered display" style="width:100%">
<thead>
<tr>
<th>No</th>
<th>Range Tanggal</th>
<th>List Karyawan</th>
<th>Created At</th>
<th>Aksi</th>
</tr>
</thead>
</table>
</div>
</div>
</div>
</div>
</div>
<!-- /.row -->
<?php $this->load->view('admin/footer') ?>
</div>
<!-- /.main-content -->
</div>
<div class="modal fade" id="modal_informasi_libur" tabindex="-1" role="dialog" aria-labelledby="myModalLabel-1">
<div class="modal-dialog modal-lg" role="document">
<form class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
<h4 class="modal-title" id="myModalLabel-1"> Informasi Libur</h4>
<!-- <p style="font-size: 10px;"><i>(Geserkan marker ke titik kordinat dinas)</i></p> -->
</div>
<div class="modal-body">
<div class="form-group">
<label for="nik">Range Tanggal</label>
<input type="text" class="form-control" id="range_tanggal" disabled>
</div>
<div class="form-group">
<label for="nik">List Karayawn</label>
<textarea name="list_karyawan" class="form-control" id="list_karyawan" cols="30" rows="10" style="resize: none;" disabled></textarea>
</div>
<div class="form-group">
<label for="nama">Keterangan</label>
<textarea name="keterangan" class="form-control" id="keterangan" cols="30" rows="10" style="resize: none;" disabled></textarea>
</div>
<div class="form-group">
<label for="nama">Created At</label>
<input type="text" class="form-control" id="created_at" disabled>
</div>
</div>
</form>
</div>
</div>
<?php $this->load->view('admin/scripts') ?>
<!-- Select2 -->
<script src="<?= base_url() ?>assets/plugin/select2/js/select2.min.js"></script>
<script type="text/javascript" src="https://cdn.jsdelivr.net/momentjs/latest/moment.min.js"></script>
<script type="text/javascript" src="https://cdn.jsdelivr.net/npm/daterangepicker/daterangepicker.min.js"></script>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/jquery.dataTables.min.js"></script>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/dataTables.bootstrap.min.js"></script>
<script>
var table;
function datatables() {
table = $('#table_list_libur').DataTable({
// "searching": false,
"lengthMenu": [
[5, 10, 15, -1],
[5, 10, 15, "All"]
],
"pageLength": 10,
"ordering": true,
"processing": true,
"serverSide": true,
// "order": [[ 4, 'desc' ]],
"ajax": {
"url": server_url + "admin/libur",
"type": "POST",
data: {
proses: 'table_libur'
},
},
"columnDefs": [{
"targets": [2, 4],
"orderable": false,
}, ],
});
}
datatables()
async function check_info(id_libur) {
// console.log(id_libur)
let data
try {
data = await $.ajax({
url: server_url_api + "libur?id_libur=" + id_libur + "&id_dinas=" + id_dinas,
type: 'get',
async: false,
beforeSend: function(res) {
block_ui("Mengambil Data Informasi Libur");
},
});
data = data.data
console.log(data);
await $.unblockUI();
$("#range_tanggal").val(data.range_tanggal)
$("#keterangan").val(data.ket)
$("#list_karyawan").val(data.list_karyawan)
$("#created_at").val(data.created_at)
$('#modal_informasi_libur').modal('show');
} catch (error) {
await $.unblockUI();
const statusCode = error.status;
console.log(error)
console.log(statusCode)
if (statusCode == 0 || statusCode == 500) return toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
const message = error.responseJSON.message
toastr.error(message);
}
// $('#modal_informasi_libur').modal('show');
}
</script>
<script>
var id_dinas = <?= $id_dinas ?>;
let today = new Date().toLocaleDateString()
let start_tanggal, end_tanggal
// console.log(today)
$(function() {
$('input[name="tanggal_libur"]').daterangepicker({
opens: 'left',
minDate: today
}, function(start, end, label) {
// console.log("A new date selection was made: " + start.format('YYYY-MM-DD') + ' to ' + end.format('YYYY-MM-DD'));
start_tanggal = start.format('YYYY-MM-DD')
end_tanggal = end.format('YYYY-MM-DD')
});
});
let data_karyawan_count = 0;
async function check_data_karyawan() {
try {
data = await $.ajax({
url: server_url_api + "karyawanAll",
type: 'get',
async: false,
beforeSend: function(res) {
block_ui("Mengambil Data Karyawan");
},
});
data = data.data
// await $.unblockUI();
const select_list_karyawan = document.getElementById("select_list_karyawan")
data_karyawan_count = data.length;
for (let i = 0; i < data.length; i++) {
let option = document.createElement("option");
option.value = data[i]['nik'];
option.text = data[i]['nama'] + " - " + data[i]['nik'];
select_list_karyawan.appendChild(option)
}
// console.log(data);
await $.unblockUI();
} catch (error) {
await $.unblockUI();
const statusCode = error.status;
console.log(error)
console.log(statusCode)
if (statusCode == 0 || statusCode == 500) return toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
// const message = error.responseJSON.message
toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
}
}
check_data_karyawan()
$("#select_list_karyawan").select2({
placeholder: " -Pilih Karyawan",
allowClear: true
});
$("#chk-2").click(function() {
if ($("#chk-2").is(':checked')) {
console.log("ini checked")
$("#select_list_karyawan > option").prop("selected", "selected");
$("#select_list_karyawan").trigger("change");
} else {
console.log("ini dischecked")
$("#select_list_karyawan").val('').change();
}
});
function check_dulu() {
// console.log("sini check dulu");
const count = $("#select_list_karyawan option:selected").length;
if (count == data_karyawan_count) {
document.getElementById("chk-2").checked = true
} else {
document.getElementById("chk-2").checked = false
}
}
function tambah_libur(e) {
e.preventDefault();
// console.log("sini tambah libur")
// console.log(start_tanggal,end_tanggal)
const list_karyawan = $("#select_list_karyawan").val();
const ket = $("#ket").val();
// console.log(ket);
let data = new FormData()
data.append('id_dinas', id_dinas)
data.append('list_karyawan', JSON.stringify(list_karyawan))
data.append('start_tanggal', start_tanggal)
data.append('end_tanggal', end_tanggal)
data.append('ket', ket)
swal({
text: `Informasi Libur Akan Ditambah ?`,
icon: "info",
buttons: {
cancel: true,
confirm: true,
},
// dangerMode: true,
}).then((yes) => {
$.ajax({
url: server_url_api + "libur",
type: 'post',
contentType: false,
processData: false,
data,
beforeSend: function(res) {
// $('#modal_karyawan').modal('hide');
block_ui("Menambah Libur");
},
success: function(response) {
$.unblockUI();
// window.location.reload();
console.log(response)
// $('#table_list_libur').dataTable().fnDestroy();
// datatables()
$("#select_list_karyawan").val('').change();
$("#ket").val("")
$('#table_list_libur').dataTable().fnDestroy();
datatables()
toastr.success(response.message);
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
$.unblockUI();
// console.log(errorThrown)
// console.log(textStatus)
const statusCode = XMLHttpRequest.status;
const responseJSON = XMLHttpRequest.responseJSON;
console.log(statusCode);
console.log(responseJSON)
if (statusCode != 500 && statusCode != 0) {
toastr.error(responseJSON.message);
} else {
toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
}
}
});
})
}
</script>
</body>
<!-- Dibuat oleh Kicap Karan. https://www.kicap-karan.com -->
</html>

View File

@ -1,368 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<?php $this->load->view("admin/header"); ?>
<body>
<?php $this->load->view("admin/side_topbar"); ?>
<div id="wrapper">
<div class="main-content">
<div class="row small-spacing">
<div class="col-lg-3 col-md-2"></div>
<div class="col-xs-12 col-lg-6 col-md-8">
<form class="box-content" onsubmit="return simpan_radius(event)">
<h4 class="box-title">Pengaturan Radius</h4>
<div class="input-group margin-bottom-20">
<input type="text" id="radius" class="form-control" placeholder="Masukkan Radius (meter)" required minlength="1" maxlength="3" value="<?= $radius ?>" onkeypress="return isNumberKey(event)">
<span class="input-group-addon b-0 text-grey">meter</span>
</div>
<div class="form-group text-center">
<button type="submit" class="btn btn-primary btn-xs waves-effect waves-light">Simpan Radius</button>
</div>
</form>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
<div class="col-lg-3 col-md-2"></div>
</div>
<div class="row small-spacing">
<div class="col-xs-12">
<div class="box-content">
<h4 class="box-title">Pengaturan Titik Lokasi Dinas</h4>
<!-- /.dropdown js__dropdown -->
<div class="form-group">
<div id="map" style="width: 100%; height: 500px"></div>
</div>
<!-- /#flot-chart-1.flot-chart -->
<div class="form-group">
<input type="text" placeholder="Masukkan Alamat Untuk Mengubah Kordinat" id="alamat" class="form-control">
<!-- <center><button type="button" class="btn btn-primary btn-xs waves-effect waves-light" onclick="buka_modal_pengaturan()">Atur Titik Kordinat</button></center> -->
</div>
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<!-- /.row -->
<?php $this->load->view('admin/footer') ?>
</div>
<!-- /.main-content -->
</div>
<div class="modal fade" id="modal_pengaturan_kordinat" tabindex="-1" role="dialog" aria-labelledby="myModalLabel-1" data-keyboard="false" data-backdrop="static">
<div class="modal-dialog modal-lg" role="document">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" onclick="rewind_button()" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
<h4 class="modal-title" id="myModalLabel-1">Pengaturan Titik Kordinat Dinas</h4>
<p style="font-size: 10px;"><i>(Geserkan marker ke titik kordinat dinas)</i></p>
</div>
<div class="modal-body">
<div class="form-group">
<!-- <input type="text" placeholder="Masukkan Alamat" id="alamat"> -->
<!-- <input type="text" placeholder="Masukkan Alamat" id="alamat" class="form-control"> -->
</div>
<div class="form-group">
<div id="map2" style="width: 100%; height: 500px"></div>
</div>
</div>
<div class="modal-footer">
<button type="button" style="display:none" class="button_simpan_marker btn btn-success btn-xs waves-effect waves-light" onclick="simpan_marker()">Simpan Marker</button>
<button type="button" style="display:none" class="button_simpan_marker btn btn-danger btn-xs waves-effect waves-light" onclick="rewind_button()" data-dismiss="modal">Batalkan</button>
<button type="button" id="button_tambah_marker" class="btn btn-primary btn-xs waves-effect waves-light" onclick="get_center()">Letak
Marker</button>
</div>
</div>
</div>
</div>
<?php $this->load->view('admin/scripts') ?>
<script src="https://maps.googleapis.com/maps/api/js?key=AIzaSyD7B9RynI4hQM_Y4BG9GYxsTLWwYkGASRo&libraries=geometry,drawing,places&v=weekly&region=ID&language=id">
</script>
<!-- <script src="https://maps.googleapis.com/maps/api/js?key=AIzaSyD7B9RynI4hQM_Y4BG9GYxsTLWwYkGASRo&&language=id&region=ID&callback=initAutocomplete&libraries=places&v=weekly&sensor=false" defer></script> -->
<script>
let map;
async function initMap() {
map = new google.maps.Map(document.getElementById("map"), {
zoom: 19.5,
center: {
lat: <?= $lat ?>,
lng: <?= $lng ?>
},
mapTypeId: 'hybrid',
streetViewControl: false,
});
const marker = new google.maps.Marker({
position: {
lat: <?= $lat ?>,
lng: <?= $lng ?>
},
map: map,
title: 'Center',
icon: 'https://maps.google.com/mapfiles/ms/icons/blue-dot.png',
});
const cityCircle = new google.maps.Circle({
strokeColor: "#FF0000",
strokeOpacity: 0.3,
strokeWeight: 0.3,
fillColor: "#FF0000",
fillOpacity: 0.3,
map,
center: {
lat: <?= $lat ?>,
lng: <?= $lng ?>
},
radius: <?= $radius ?>,
});
}
google.maps.event.addDomListener(window, 'load', initMap);
</script>
<script>
// function buka_modal_pengaturan() {
// $('#modal_pengaturan_kordinat').modal('show');
// }
var geocoder = new google.maps.Geocoder();
var marker;
var lat, lng;
function geocodePosition(pos) {
geocoder.geocode({
latLng: pos
});
}
function updateMarkerPosition(latLng) {
// document.getElementById('info').value = [
console.log(latLng.lat(), latLng.lng())
lat = latLng.lat()
lng = latLng.lng()
console.log(lat, lng)
}
let map2;
function initAutocomplete() {
map2 = new google.maps.Map(document.getElementById("map2"), {
center: {
lat: -3.916417,
lng: 119.7329218
},
zoom: 16,
mapTypeId: "hybrid"
}); // Create the search box and link it to the UI element.
const input = document.getElementById("alamat");
const searchBox = new google.maps.places.SearchBox(input);
// map.controls[google.maps.ControlPosition.TOP_LEFT].push(input); // Bias the SearchBox results towards current map's viewport.
map2.addListener("bounds_changed", () => {
searchBox.setBounds(map2.getBounds());
});
// more details for that place.
searchBox.addListener("places_changed", () => {
if (typeof marker !== 'undefined') {
// console.log('ada');
marker.setMap(null);
}
const places = searchBox.getPlaces();
console.log(places)
// $("#sini_modal").modal();
if (places.length == 0) {
return;
} // Clear out the old markers.
const bounds = new google.maps.LatLngBounds();
// console.log(bounds);
places.forEach(place => {
// console.log(place)
if (!place.geometry) {
console.log("Returned place contains no geometry");
return;
}
if (place.geometry.viewport) {
var centernya = map2.setCenter(place.geometry.location);
map2.fitBounds(place.geometry.viewport);
map2.setZoom(14);
} else {
var centernya = map2.setCenter(place.geometry.viewport);
map2.setCenter(place.geometry.location);
map2.setZoom(14);
}
// console.log(updateMarkerPosition(place.geometry.location));
$("#alamat").val("");
$('#modal_pengaturan_kordinat').modal('show');
});
});
}
google.maps.event.addDomListener(window, 'load', initAutocomplete);
function get_center() {
// set marker to null to remove marker
const rndInt = Math.floor(Math.random() * 6) + 1
let center = map2.getCenter();
lat = center.lat()
lng = center.lng()
// console.log(lat, lng)
// add marker to map2
marker = new google.maps.Marker({
uniqueId: rndInt,
position: {
lat: center.lat(),
lng: center.lng()
},
map: map2,
title: 'Center',
icon: 'https://maps.google.com/mapfiles/ms/icons/green-dot.png',
draggable: true,
});
// add listener to marker
google.maps.event.addListener(marker, 'dragend', function(event) {
updateMarkerPosition(event.latLng);
});
$(".button_simpan_marker").removeAttr("style");
$("#button_tambah_marker").attr("style", "display:none");
}
function simpan_marker() {
$.ajax({
url: server_url_api + "pengaturan_lokasi",
type: 'put',
data: {
id: <?= $id_dinas ?>,
lat: lat,
lng: lng
},
beforeSend: function(res) {
$('#modal_pengaturan_kordinat').modal('hide');
block_ui("Mengubah Titik Kordinat Dinas");
},
success: function(response) {
$.unblockUI();
window.location.reload();
// console.log(response)
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
$.unblockUI();
// console.log(errorThrown)
// console.log(textStatus)
const statusCode = XMLHttpRequest.status;
const responseJSON = XMLHttpRequest.responseJSON;
console.log(statusCode);
console.log(responseJSON)
if (statusCode != 500) {
toastr.error(responseJSON.message);
} else {
toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
}
}
});
}
function rewind_button() {
$(".button_simpan_marker").attr("style", "display:none");
$("#button_tambah_marker").removeAttr("style");
lat = null;
lng = null;
}
</script>
<script>
function simpan_radius(e) {
e.preventDefault();
const radius = $("#radius").val();
if (radius == <?= $radius ?>) return toastr.warning("Tiada Perubahan Radius");
swal({
text: `Ubah radius dari <?= $radius ?> meter menjadi \n ${radius} meter`,
icon: "info",
buttons: {
cancel: true,
confirm: true,
},
// dangerMode: true,
}).then((yes) => {
if (yes) {
$.ajax({
url: server_url_api + "pengaturan_radius",
type: 'put',
data: {
id: <?= $id_dinas ?>,
radius: radius,
},
beforeSend: function(res) {
block_ui("Mengubah Radius");
},
success: function(response) {
$.unblockUI();
window.location.reload();
// console.log(response)
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
$.unblockUI();
// console.log(errorThrown)
// console.log(textStatus)
const statusCode = XMLHttpRequest.status;
const responseJSON = XMLHttpRequest.responseJSON;
console.log(statusCode);
console.log(responseJSON)
if (statusCode != 500) {
toastr.error(responseJSON.message);
} else {
toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
}
}
});
}
});
}
</script>
</body>
<!-- Dibuat oleh Kicap Karan. https://www.kicap-karan.com -->
</html>

View File

@ -1,349 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<?php $this->load->view("admin/header"); ?>
<body>
<?php $this->load->view("admin/side_topbar"); ?>
<div id="wrapper">
<div class="main-content">
<div class="row small-spacing">
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title">Form Perjalanan Dinas </h4>
<form class="card-content" onsubmit="return tambah_perjalanan_dinas(event)">
<div class="form-group">
<label for="tanggal_perjalanan_dinas">Range Tanggal</label>
<input type="text" name="tanggal_perjalanan_dinas" class="form-control" value="" reqruied />
</div>
<div class="form-group">
<label for="tanggal_perjalanan_dinas">List Karyawan</label>
<div class="row small-spacing" style="overflow-x: auto;">
<div class="col-xs-9">
<select multiple id="select_list_karyawan" class="form-control" onchange="check_dulu()" required>
</select>
</div>
<div class="col-xs-3">
<li class="checkbox">
<input type="checkbox" id="chk-2"><label for="chk-2">Semua</label>
</li>
</div>
</div>
</div>
<div class="form-group">
<label for="tanggal_perjalanan_dinas">Keterangan</label>
<textarea name="" id="ket" cols="30" rows="10" class="form-control" style="resize: none" placeholder="Keterangan Perjalanan Dinas" required></textarea>
</div>
<div class="form-group text-center">
<button type="submit" class="btn btn-primary btn-xs waves-effect waves-light">
Tambah Perjalanan Dinas
</button>
</div>
</form>
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<div class="row small-spacing">
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title">List Libur</h4>
<div class="card-content">
<div style="overflow-x: auto">
<table id="table_list_perjalanan_dinas" class="table table-striped table-bordered display" style="width:100%">
<thead>
<tr>
<th>No</th>
<th>Range Tanggal</th>
<th>List Karyawan</th>
<th>Created At</th>
<th>Aksi</th>
</tr>
</thead>
</table>
</div>
</div>
</div>
</div>
</div>
<!-- /.row -->
<?php $this->load->view('admin/footer') ?>
</div>
<!-- /.main-content -->
</div>
<div class="modal fade" id="modal_informasi_perjalanan_dinas" tabindex="-1" role="dialog" aria-labelledby="myModalLabel-1">
<div class="modal-dialog modal-lg" role="document">
<form class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
<h4 class="modal-title" id="myModalLabel-1"> Informasi Perjalanan Dinas</h4>
<!-- <p style="font-size: 10px;"><i>(Geserkan marker ke titik kordinat dinas)</i></p> -->
</div>
<div class="modal-body">
<div class="form-group">
<label for="nik">Range Tanggal</label>
<input type="text" class="form-control" id="range_tanggal" disabled>
</div>
<div class="form-group">
<label for="nik">List Karayawn</label>
<textarea name="list_karyawan" class="form-control" id="list_karyawan" cols="30" rows="10" style="resize: none;" disabled></textarea>
</div>
<div class="form-group">
<label for="nama">Keterangan</label>
<textarea name="keterangan" class="form-control" id="keterangan" cols="30" rows="10" style="resize: none;" disabled></textarea>
</div>
<div class="form-group">
<label for="nama">Created At</label>
<input type="text" class="form-control" id="created_at" disabled>
</div>
</div>
</form>
</div>
</div>
<?php $this->load->view('admin/scripts') ?>
<!-- Select2 -->
<script src="<?= base_url() ?>assets/plugin/select2/js/select2.min.js"></script>
<script type="text/javascript" src="https://cdn.jsdelivr.net/momentjs/latest/moment.min.js"></script>
<script type="text/javascript" src="https://cdn.jsdelivr.net/npm/daterangepicker/daterangepicker.min.js"></script>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/jquery.dataTables.min.js"></script>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/dataTables.bootstrap.min.js"></script>
<script>
var table;
function datatables() {
table = $('#table_list_perjalanan_dinas').DataTable({
// "searching": false,
"lengthMenu": [
[5, 10, 15, -1],
[5, 10, 15, "All"]
],
"pageLength": 10,
"ordering": true,
"processing": true,
"serverSide": true,
// "order": [[ 4, 'desc' ]],
"ajax": {
"url": server_url + "admin/perjalanan_dinas",
"type": "POST",
data: {
proses: 'table_dinas'
},
},
"columnDefs": [{
"targets": [2, 4],
"orderable": false,
}, ],
});
}
datatables()
async function check_info(id_perjalanan_dinas) {
// console.log(id_perjalanan_dinas)
let data
try {
data = await $.ajax({
url: server_url_api + "perjalanan_dinas?id_perjalanan_dinas=" + id_perjalanan_dinas + "&id_dinas=" + id_dinas,
type: 'get',
async: false,
beforeSend: function(res) {
block_ui("Mengambil Data Informasi Perjalanan Dinas");
},
});
data = data.data
console.log(data);
await $.unblockUI();
$("#range_tanggal").val(data.range_tanggal)
$("#keterangan").val(data.ket)
$("#list_karyawan").val(data.list_karyawan)
$("#created_at").val(data.created_at)
$('#modal_informasi_perjalanan_dinas').modal('show');
} catch (error) {
await $.unblockUI();
const statusCode = error.status;
console.log(error)
console.log(statusCode)
if (statusCode == 0 || statusCode == 500) return toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
const message = error.responseJSON.message
toastr.error(message);
}
// $('#modal_informasi_perjalanan_dinas').modal('show');
}
</script>
<script>
var id_dinas = <?= $id_dinas ?>;
let today = new Date().toLocaleDateString()
let start_tanggal, end_tanggal
// console.log(today)
$(function() {
$('input[name="tanggal_perjalanan_dinas"]').daterangepicker({
opens: 'left',
minDate: today
}, function(start, end, label) {
// console.log("A new date selection was made: " + start.format('YYYY-MM-DD') + ' to ' + end.format('YYYY-MM-DD'));
start_tanggal = start.format('YYYY-MM-DD')
end_tanggal = end.format('YYYY-MM-DD')
});
});
let data_karyawan_count = 0;
async function check_data_karyawan() {
try {
data = await $.ajax({
url: server_url_api + "karyawanAll",
type: 'get',
async: false,
beforeSend: function(res) {
block_ui("Mengambil Data Karyawan");
},
});
data = data.data
// await $.unblockUI();
const select_list_karyawan = document.getElementById("select_list_karyawan")
data_karyawan_count = data.length;
for (let i = 0; i < data.length; i++) {
let option = document.createElement("option");
option.value = data[i]['nik'];
option.text = data[i]['nama'] + " - " + data[i]['nik'];
select_list_karyawan.appendChild(option)
}
// console.log(data);
await $.unblockUI();
} catch (error) {
await $.unblockUI();
const statusCode = error.status;
console.log(error)
console.log(statusCode)
if (statusCode == 0 || statusCode == 500) return toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
// const message = error.responseJSON.message
toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
}
}
check_data_karyawan()
$("#select_list_karyawan").select2({
placeholder: " -Pilih Karyawan",
allowClear: true
});
$("#chk-2").click(function() {
if ($("#chk-2").is(':checked')) {
console.log("ini checked")
$("#select_list_karyawan > option").prop("selected", "selected");
$("#select_list_karyawan").trigger("change");
} else {
console.log("ini dischecked")
$("#select_list_karyawan").val('').change();
}
});
function check_dulu() {
// console.log("sini check dulu");
const count = $("#select_list_karyawan option:selected").length;
if (count == data_karyawan_count) {
document.getElementById("chk-2").checked = true
} else {
document.getElementById("chk-2").checked = false
}
}
function tambah_perjalanan_dinas(e) {
e.preventDefault();
// console.log("sini tambah libur")
// console.log(start_tanggal,end_tanggal)
const list_karyawan = $("#select_list_karyawan").val();
const ket = $("#ket").val();
// console.log(ket);
let data = new FormData()
data.append('id_dinas', id_dinas)
data.append('list_karyawan', JSON.stringify(list_karyawan))
data.append('start_tanggal', start_tanggal)
data.append('end_tanggal', end_tanggal)
data.append('ket', ket)
swal({
text: `Informasi Perjalanan Dinas Akan Ditambah ?`,
icon: "info",
buttons: {
cancel: true,
confirm: true,
},
// dangerMode: true,
}).then((yes) => {
$.ajax({
url: server_url_api + "perjalanan_dinas",
type: 'post',
contentType: false,
processData: false,
data,
beforeSend: function(res) {
// $('#modal_karyawan').modal('hide');
block_ui("Menambah Perjalanan Dinas");
},
success: function(response) {
$.unblockUI();
// window.location.reload();
console.log(response)
// $('#table_list_karyawan').dataTable().fnDestroy();
// datatables()
toastr.success(response.message);
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
$.unblockUI();
// console.log(errorThrown)
// console.log(textStatus)
const statusCode = XMLHttpRequest.status;
const responseJSON = XMLHttpRequest.responseJSON;
console.log(statusCode);
console.log(responseJSON)
if (statusCode != 500 && statusCode != 0) {
toastr.error(responseJSON.message);
} else {
toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
}
}
});
})
}
</script>
</body>
<!-- Dibuat oleh Kicap Karan. https://www.kicap-karan.com -->
</html>

View File

@ -0,0 +1,469 @@
<!DOCTYPE html>
<html lang="en">
<?php $this->load->view("admin/header"); ?>
<body>
<?php $this->load->view("admin/side_topbar"); ?>
<div id="wrapper">
<div class="main-content">
<div class="row small-spacing">
<!-- /.col-xs-12 -->
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title" id="header_absensi">List Penduduk</h4>
<div class="card-content">
<!-- create button for 'Tambah Penduduk' -->
<button type="button" class="btn btn-primary btn-xs" onclick="proses_bantuan()">
<i class="fa fa-book"></i> Proses Bantuan Sosial
</button>
<br><br>
<div style="overflow-x: auto">
<table id="table_list_penduduk" class="table table-striped table-bordered display" style="width:100%">
<thead>
<tr>
<th>NIK</th>
<th>Nama</th>
<th>Status Bantuan</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
</div>
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<!-- /.row -->
<div class="row small-spacing tampilkan" style="display: none;">
<!-- /.col-xs-12 -->
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title" id="header_absensi">Matriks Keputusan</h4>
<div class="card-content">
<div style="overflow-x: auto">
<table id="table_matriks_keputusan" class="table table-striped table-bordered display" style="width:100%">
<thead>
<tr>
<th>NIK</th>
<th>Kriteria Umur</th>
<th>Kriteria Pekerjaan</th>
<th>Kriteria Penghasilan</th>
<th>Kriteria Jumlah Tanggungan</th>
<th>Kriteria Status Rumah</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
</div>
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<div class="row small-spacing tampilkan" style="display: none;">
<!-- /.col-xs-12 -->
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title" id="header_absensi">Matriks Normalisasi</h4>
<div class="card-content">
<div style="overflow-x: auto">
<table id="table_matriks_normalisasi" class="table table-striped table-bordered display" style="width:100%">
<thead>
<tr>
<th>NIK</th>
<th>Kriteria Umur</th>
<th>Kriteria Pekerjaan</th>
<th>Kriteria Penghasilan</th>
<th>Kriteria Jumlah Tanggungan</th>
<th>Kriteria Status Rumah</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
</div>
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<div class="row small-spacing tampilkan" style="display: none;">
<!-- /.col-xs-12 -->
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title" id="header_absensi">Normalisasi Terbobot</h4>
<div class="card-content">
<div style="overflow-x: auto">
<table id="table_normalisasi_terbobot" class="table table-striped table-bordered display" style="width:100%">
<thead>
<tr>
<th>NIK</th>
<th>Kriteria Umur</th>
<th>Kriteria Pekerjaan</th>
<th>Kriteria Penghasilan</th>
<th>Kriteria Jumlah Tanggungan</th>
<th>Kriteria Status Rumah</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
</div>
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<div class="row small-spacing tampilkan" style="display: none;">
<!-- /.col-xs-12 -->
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title" id="header_absensi">Ideal Positif</h4>
<div class="card-content">
<div style="overflow-x: auto">
<table id="table_ideal_positif" class="table table-striped table-bordered display" style="width:100%">
<thead>
<tr>
<th>Kriteria Umur</th>
<th>Kriteria Pekerjaan</th>
<th>Kriteria Penghasilan</th>
<th>Kriteria Jumlah Tanggungan</th>
<th>Kriteria Status Rumah</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
</div>
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<div class="row small-spacing tampilkan" style="display: none;">
<!-- /.col-xs-12 -->
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title" id="header_absensi">Ideal Negatif</h4>
<div class="card-content">
<div style="overflow-x: auto">
<table id="table_ideal_negatif" class="table table-striped table-bordered display" style="width:100%">
<thead>
<tr>
<th>Kriteria Umur</th>
<th>Kriteria Pekerjaan</th>
<th>Kriteria Penghasilan</th>
<th>Kriteria Jumlah Tanggungan</th>
<th>Kriteria Status Rumah</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
</div>
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<div class="row small-spacing tampilkan" style="display: none;">
<!-- /.col-xs-12 -->
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title" id="header_absensi">preverensi</h4>
<div class="card-content">
<div style="overflow-x: auto">
<table id="table_preverensi" class="table table-striped table-bordered display" style="width:100%">
<thead>
<tr>
<th>NIK</th>
<th>Preverensi</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
</div>
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<?php $this->load->view('admin/footer') ?>
</div>
<!-- /.main-content -->
</div>
<!-- create modal for 'Tambah Penduduk' -->
<div class="modal fade" id="modal_add_penduduk" tabindex="-1" role="dialog" aria-labelledby="modal_add_penduduk" aria-hidden="true">
<div class="modal-dialog modal-lg" role="document">
<div class="modal-content">
<div class="modal-header">
<h4 class="modal-title" id="modal_add_penduduk"></h4>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<form id="form_add_penduduk" onsubmit="return tambah_edit_penduduk(event)">
<div class="modal-body">
<div class="form-group">
<input type="hidden" id="status">
<label for="nik">NIK</label>
<input type="text" class="form-control" id="nik" name="nik" placeholder="Masukkan NIK" onkeypress="return isNumberKey(event)" minlength="16" maxlength="16" required>
</div>
<div class="form-group">
<label for="nama">Nama</label>
<input type="text" class="form-control" id="nama" name="nama" placeholder="Masukkan Nama" required>
</div>
<div class="form-group">
<label for="umur">Tanggal Lahir</label>
<input type="date" class="form-control" id="tgl_lahir" name="tgl_lahir" placeholder="Masukkan Tanggal Lahir" required>
</div>
<div class="form-group">
<label for="jenis_kelamin">Jenis Kelamin</label>
<select class="form-control" id="jenis_kelamin" name="jenis_kelamin" required>
<option value="">Pilih Jenis Kelamin</option>
<option value="Laki-laki">Laki-laki</option>
<option value="Perempuan">Perempuan</option>
</select>
</div>
<div class="form-group">
<label for="alamat">Alamat</label>
<textarea class="form-control" id="alamat" name="alamat" placeholder="Masukkan Alamat" style="resize :none;" required></textarea>
</div>
<div class="form-group">
<label for="no_hp">No HP</label>
<input type="text" class="form-control" id="no_hp" name="no_hp" placeholder="Masukkan No HP" onkeypress="return isNumberKey(event)" minlength="9" maxlength="13" required>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary btn-xs" data-dismiss="modal">Batal</button>
<button type="submit" class="btn btn-primary btn-xs" id="btn_add_penduduk">Simpan</button>
<button type="submit" class="btn btn-primary btn-xs" id="btn_update_penduduk">Update</button>
</div>
</form>
</div>
</div>
</div>
<?php $this->load->view('admin/scripts') ?>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/jquery.dataTables.min.js"></script>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/dataTables.bootstrap.min.js"></script>
<script>
var data_lama;
function datatables() {
table = $('#table_list_penduduk').DataTable({
// "searching": false,
"lengthMenu": [
[5, 10, 15, -1],
[5, 10, 15, "All"]
],
"pageLength": 10,
"ordering": true,
"processing": true,
"serverSide": true,
// "order": [[ 4, 'desc' ]],
"ajax": {
"url": server_url + "admin/topsis",
"type": "POST",
data: {
proses: 'table_penduduk'
},
},
"columnDefs": [{
"targets": [2, 3],
"orderable": false,
}, ],
});
}
datatables()
function status_bantuan(nik) {
// console.log(nik)
window.location.href = server_url + "admin/topsis/" + nik
}
function proses_bantuan() {
// console.log("sini proses bantuan")
ajax_proses = $.ajax({
url: server_url_api + "bantuan",
type: "get",
dataType: "JSON",
beforeSend: function() {
block_ui("Menyimpan Data Penduduk");
},
success: function(data) {
console.log(data)
// show class tampilkan
$('.tampilkan').removeAttr('style')
const matriks_keputusan = data.matriks_keputusan
const matriks_normalisasi = data.matriks_normalisasi
const normalisasi_terbobot = data.normalisasi_terbobot
const preverensi = data.preverensi
// insert data matriks_keputusan to table table_matriks_keputusan body
let html_matriks_keputusan = ''
let html_matriks_normalisasi = ''
let html_normalisasi_terbobot = ''
let html_preverensi = ''
for (let i = 0; i < matriks_keputusan.length; i++) {
html_matriks_keputusan += '<tr>'
html_matriks_keputusan += '<td>' + matriks_keputusan[i].nik + '</td>'
html_matriks_keputusan += '<td>' + matriks_keputusan[i].kriteria_umur + '</td>'
html_matriks_keputusan += '<td>' + matriks_keputusan[i].kriteria_pekerjaan + '</td>'
html_matriks_keputusan += '<td>' + matriks_keputusan[i].kriteria_penghasilan + '</td>'
html_matriks_keputusan += '<td>' + matriks_keputusan[i].kriteria_jumlah_tanggungan + '</td>'
html_matriks_keputusan += '<td>' + matriks_keputusan[i].kriteria_jenis_rumah + '</td>'
html_matriks_keputusan += '</tr>'
html_matriks_normalisasi += '<tr>'
html_matriks_normalisasi += '<td>' + matriks_normalisasi[i].nik + '</td>'
html_matriks_normalisasi += '<td>' + matriks_normalisasi[i].kriteria_umur + '</td>'
html_matriks_normalisasi += '<td>' + matriks_normalisasi[i].kriteria_pekerjaan + '</td>'
html_matriks_normalisasi += '<td>' + matriks_normalisasi[i].kriteria_penghasilan + '</td>'
html_matriks_normalisasi += '<td>' + matriks_normalisasi[i].kriteria_jumlah_tanggungan + '</td>'
html_matriks_normalisasi += '<td>' + matriks_normalisasi[i].kriteria_jenis_rumah + '</td>'
html_matriks_normalisasi += '</tr>'
html_normalisasi_terbobot += '<tr>'
html_normalisasi_terbobot += '<td>' + normalisasi_terbobot[i].nik + '</td>'
html_normalisasi_terbobot += '<td>' + normalisasi_terbobot[i].kriteria_umur + '</td>'
html_normalisasi_terbobot += '<td>' + normalisasi_terbobot[i].kriteria_pekerjaan + '</td>'
html_normalisasi_terbobot += '<td>' + normalisasi_terbobot[i].kriteria_penghasilan + '</td>'
html_normalisasi_terbobot += '<td>' + normalisasi_terbobot[i].kriteria_jumlah_tanggungan + '</td>'
html_normalisasi_terbobot += '<td>' + normalisasi_terbobot[i].kriteria_jenis_rumah + '</td>'
html_normalisasi_terbobot += '</tr>'
html_preverensi += '<tr>'
html_preverensi += '<td>' + preverensi[i].nik + '</td>'
html_preverensi += '<td>' + preverensi[i].preverensi + '</td>'
html_preverensi += '</tr>'
}
$('#table_matriks_keputusan tbody').html(html_matriks_keputusan)
$('#table_matriks_normalisasi tbody').html(html_matriks_normalisasi)
$('#table_normalisasi_terbobot tbody').html(html_normalisasi_terbobot)
$('#table_preverensi tbody').html(html_preverensi)
// datatable matriks_keputusan
$('#table_matriks_keputusan').DataTable();
$('#table_matriks_normalisasi').DataTable();
$('#table_normalisasi_terbobot').DataTable();
$('#table_preverensi').DataTable();
const ideal_positif = data.ideal_positif
let html_ideal_positif = ''
html_ideal_positif += '<tr>'
html_ideal_positif += '<td>' + ideal_positif.kriteria_umur + '</td>'
html_ideal_positif += '<td>' + ideal_positif.kriteria_pekerjaan + '</td>'
html_ideal_positif += '<td>' + ideal_positif.kriteria_penghasilan + '</td>'
html_ideal_positif += '<td>' + ideal_positif.kriteria_jumlah_tanggungan + '</td>'
html_ideal_positif += '<td>' + ideal_positif.kriteria_jenis_rumah + '</td>'
html_ideal_positif += '</tr>'
$('#table_ideal_positif tbody').html(html_ideal_positif)
$('#table_ideal_positif').DataTable();
const ideal_negatif = data.ideal_negatif
let html_ideal_negatif = ''
html_ideal_negatif += '<tr>'
html_ideal_negatif += '<td>' + ideal_negatif.kriteria_umur + '</td>'
html_ideal_negatif += '<td>' + ideal_negatif.kriteria_pekerjaan + '</td>'
html_ideal_negatif += '<td>' + ideal_negatif.kriteria_penghasilan + '</td>'
html_ideal_negatif += '<td>' + ideal_negatif.kriteria_jumlah_tanggungan + '</td>'
html_ideal_negatif += '<td>' + ideal_negatif.kriteria_jenis_rumah + '</td>'
html_ideal_negatif += '</tr>'
$('#table_ideal_negatif tbody').html(html_ideal_negatif)
$('#table_ideal_negatif').DataTable();
$('#table_list_penduduk').dataTable().fnDestroy();
datatables();
$.unblockUI();
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
const statusCode = XMLHttpRequest.status;
const responseJSON = XMLHttpRequest.responseJSON;
console.log(statusCode);
console.log(responseJSON)
// if (statusCode != 500 || statusCode != 0) {
// toastr.error(responseJSON.message);
// } else {
// toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
// }
// $.unblockUI();
}
})
}
</script>
</body>
<!-- Dibuat oleh Kicap Karan. https://www.kicap-karan.com -->
</html>

View File

@ -0,0 +1,239 @@
<!DOCTYPE html>
<html lang="en">
<?php $this->load->view("admin/header"); ?>
<body>
<?php $this->load->view("admin/side_topbar"); ?>
<div id="wrapper">
<div class="main-content">
<div class="row small-spacing">
<!-- /.col-xs-12 -->
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title" id="header_absensi">Detail Kriteria Penduduk</h4>
<div class="card-content">
<!-- create input below like umur, pekerjaan, penghasilan , jumlah tanggungan dan jenis rumah -->
<form class="form-horizontal" onsubmit="return cek_status_bantuan_sosial(event)">
<div class="form-group">
<label class="col-sm-2 control-label">NIK</label>
<div class="col-sm-8">
<input type="text" class="form-control" id="nik" name="nik" value="<?= $nik ?>" placeholder="NIK" disabled>
</div>
<div class="col-sm-2"></div>
</div>
<div class="form-group">
<label class="col-sm-2 control-label">Nama</label>
<div class="col-sm-8">
<input type="text" class="form-control" id="nama" name="nama" value="<?= $nama ?>" placeholder="Nama" disabled>
</div>
<div class="col-sm-2"></div>
</div>
<div class="form-group">
<label class="col-sm-2 control-label">Umur</label>
<div class="col-sm-8">
<input type="text" class="form-control" id="umur" name="umur" value="<?= $umur ?>" placeholder="Umur" disabled>
</div>
<div class="col-sm-2"></div>
</div>
<div class="form-group">
<label for="pekerjaan" class="col-sm-2 control-label">Pekerjaan</label>
<div class="col-sm-8">
<select class="form-control" id="pekerjaan" name="pekerjaan" required>
<option value='' selected disabled>-Pilih Pekerjaan</option>
<option value="1">PNS</option>
<option value="2">Wiraswasta</option>
<option value="3">Petani</option>
<option value="4">Buruh</option>
</select>
</div>
<div class="col-sm-2"></div>
</div>
<div class="form-group">
<label for="penghasilan" class="col-sm-2 control-label">Penghasilan</label>
<div class="col-sm-8">
<select class="form-control" id="penghasilan" name="penghasilan" required>
<option value='' selected disabled>-Pilih Penghasilan</option>
<option value="4">Kurang dari Rp. 3.000.000</option>
<option value="3">Rp. 3.000.000 - Rp. 5.000.000</option>
<option value="2">Rp. 5.000.000 - Rp. 8.000.000</option>
<option value="1">Lebih dari Rp. 8.000.000</option>
</select>
</div>
<div class="col-sm-2"></div>
</div>
<div class="form-group">
<label for="jumlah_tanggungan" class="col-sm-2 control-label">Jumlah Tanggungan</label>
<div class="col-sm-8">
<select class="form-control" id="jumlah_tanggungan" name="jumlah_tanggungan" required>
<option value='' selected disabled>-Pilih Tanggungan</option>
<option value="1">Tiada</option>
<option value="2">Kurang dari 3</option>
<option value="3">3 - 5</option>
<option value="4">Lebih dari 5</option>
</select>
</div>
<div class="col-sm-2"></div>
</div>
<div class="form-group">
<label for="jenis_rumah" class="col-sm-2 control-label">Jenis Rumah</label>
<div class="col-sm-8">
<select class="form-control" id="jenis_rumah" name="jenis_rumah" required>
<option value='' selected disabled>-Pilih Jenis Rumah</option>
<option value="1">Rumah Sendiri</option>
<option value="3">Rumah Sewa</option>
<option value="4">Rumah Kontrak</option>
<option value="2">Rumah Keluarga</option>
</select>
</div>
<div class="col-sm-2"></div>
</div>
<div class="form-group text-center">
<button type="submit" class="btn btn-primary btn-xs waves-effect waves-light" id="btn_simpan">Masukkan Detail Kriteria</button>
</div>
</form>
</div>
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<!-- /.row -->
<div class="row small-spacing">
<!-- /.col-xs-12 -->
<div class="col-xs-12">
<div class="box-content card">
<h4 class="box-title" id="header_absensi">Status Bantuan</h4>
<div class="card-content">
</div>
</div>
<!-- /.box-content -->
</div>
<!-- /.col-xs-12 -->
</div>
<?php $this->load->view('admin/footer') ?>
</div>
<!-- /.main-content -->
</div>
<?php $this->load->view('admin/scripts') ?>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/jquery.dataTables.min.js"></script>
<script src="<?= base_url() ?>assets/plugin/datatables/media/js/dataTables.bootstrap.min.js"></script>
<script>
var data_lama;
async function cek_data(){
const nik = $('#nik').val();
let data
try {
data = await $.ajax({
url: server_url_api + "topsis?nik=" + nik,
type: 'get',
async: false,
beforeSend: function(res) {
block_ui("Mengambil Data Kriteria");
},
});
data = data.data
data_lama = data
console.log(data)
if(data != null){
$("#pekerjaan").val(data.bobot_pekerjaan)
$("#penghasilan").val(data.bobot_penghasilan)
$("#jumlah_tanggungan").val(data.bobot_jumlah_tanggungan)
$("#jenis_rumah").val(data.bobot_jenis_rumah)
$("#btn_simpan").html("Update Detail Kriteria")
}
await $.unblockUI();
} catch (error) {
await $.unblockUI();
const statusCode = error.status;
console.log(error)
console.log(statusCode)
if (statusCode == 0 || statusCode == 500) return toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
const message = error.responseJSON.message
toastr.error(message);
}
}
cek_data()
function cek_status_bantuan_sosial(e) {
e.preventDefault();
const nik = $('#nik').val();
const umur = $('#umur').val();
const bobot_pekerjaan = $('#pekerjaan').val();
const bobot_penghasilan = $('#penghasilan').val();
const bobot_jumlah_tanggungan = $('#jumlah_tanggungan').val();
const bobot_jenis_rumah = $('#jenis_rumah').val();
var bobot_umur
if (umur < 25) {
bobot_umur = 1
} else if (umur >= 25 && umur <= 35) {
bobot_umur = 2
} else if (umur >= 36 && umur <= 45) {
bobot_umur = 3
} else if (umur >= 46) {
bobot_umur = 4
}
$.ajax({
url: server_url_api + "topsis",
type: 'POST',
dataType: 'json',
data: {
nik: nik,
bobot_umur: bobot_umur,
bobot_pekerjaan: bobot_pekerjaan,
bobot_penghasilan: bobot_penghasilan,
bobot_jumlah_tanggungan: bobot_jumlah_tanggungan,
bobot_jenis_rumah: bobot_jenis_rumah
},
beforeSend: function(res) {
// block_ui("Loading Status Bantuan Menggunakan Metode Topsis");
},
success: function(data) {
console.log(data)
$.unblockUI();
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
const statusCode = XMLHttpRequest.status;
const responseJSON = XMLHttpRequest.responseJSON;
console.log(statusCode);
console.log(responseJSON)
if (statusCode != 500 || statusCode != 0) {
toastr.error(responseJSON.message);
} else {
toastr.error("Jaringan atau server bermasalah, sila refresh kembali halaman");
}
$.unblockUI();
}
})
}
</script>
</body>
<!-- Dibuat oleh Kicap Karan. https://www.kicap-karan.com -->
</html>

View File

@ -1,11 +1,11 @@
<div class="main-menu">
<header class="header">
<a href="<?= base_url("admin") ?>" class="logo"></i><?= $level ?></a>
<a href="<?= base_url("admin") ?>" class="logo"></i>Admin</a>
<button type="button" class="button-close fa fa-times js__menu_close"></button>
<div class="user">
<a href="#" class="avatar"><img src="<?= base_url() ?>assets/images/avatar-sm-5.jpg" alt=""><span class="status online"></span></a>
<h5 class="name"><a href="3"><?= $nama ?></a></h5>
<h5 class="position"><?= $level ?></h5>
<h5 class="name"><a href="3">Administratif</a></h5>
<h5 class="position">Admin</h5>
<!-- /.name -->
</div>
@ -21,23 +21,8 @@
<li <?php if($header == "Halaman Utama"){echo 'class="current"';} ?>>
<a class="waves-effect" href="<?= base_url("admin") ?>"><i class="menu-icon mdi mdi-view-dashboard"></i><span>Halaman Utama</span></a>
</li>
<li <?php if($header == "Halaman Jam Kerja"){echo 'class="current"';} ?>>
<a class="waves-effect" href="<?= base_url("admin/jam_kerja") ?>"><i class="menu-icon fa fa-clock-o"></i><span>Halaman Jam Kerja</span></a>
</li>
<li <?php if($header == "Halaman Pengaturan Libur"){echo 'class="current"';} ?>>
<a class="waves-effect" href="<?= base_url("admin/libur") ?>"><i class="menu-icon fa fa-calendar"></i><span>Pengaturan Libur</span></a>
</li>
<li <?php if($header == "Halaman Pengaturan Perjalanan Dinas"){echo 'class="current"';} ?>>
<a class="waves-effect" href="<?= base_url("admin/perjalanan_dinas") ?>"><i class="menu-icon fa fa-calendar"></i><span>Perjalanan Dinas</span></a>
</li>
<li <?php if($header == "Halaman Pengaturan Lokasi Dinas"){echo 'class="current"';} ?>>
<a class="waves-effect" href="<?= base_url("admin/pengaturan") ?>"><i class="menu-icon mdi mdi-desktop-mac"></i><span>Pengaturan Lokasi Dinas</span></a>
</li>
<li <?php if($header == "Halaman Karyawan"){echo 'class="current"';} ?>>
<a class="waves-effect" href="<?= base_url("admin/karyawan") ?>"><i class="menu-icon zmdi zmdi-accounts-alt"></i><span>Halaman Karyawan</span></a>
</li>
<li <?php if($header == "Halaman Laporan"){echo 'class="current"';} ?>>
<a class="waves-effect" href="<?= base_url("admin/laporan") ?>"><i class="menu-icon zmdi zmdi-comment-list"></i><span>Halaman Laporan</span></a>
<li <?php if($header == "Halaman Topsis"){echo 'class="current"';} ?>>
<a class="waves-effect" href="<?= base_url("admin/topsis") ?>"><i class="menu-icon fa fa-clock-o"></i><span>Halaman Topsis</span></a>
</li>
<li >
<a class="waves-effect" href="<?= base_url("admin/logout") ?>"><i class="menu-icon mdi mdi-logout"></i><span>Logout</span></a>

View File

@ -9,7 +9,7 @@
<meta name="description" content="">
<meta name="author" content="">
<title>Sistem Kedisiplinan Dinas Pariwisata Dan Kebudayaan Kabupaten Mamuju Tengah - Halaman Login</title>
<title>Sistem Bantuan Sosial Tunai Dinas Sosial, Pariwisata dan Kebudayaan Pinrang - Halaman Login</title>
<link rel="stylesheet" href="<?= base_url() ?>assets/styles/style.min.css">
<link rel="apple-touch-icon" sizes="57x57" href="<?= base_url() ?>assets<?= base_url() ?>assets/images/favico/apple-icon-57x57.png">
@ -44,9 +44,9 @@
<div id="single-wrapper">
<form action="#" class="frm-single" onsubmit="return login(event)">
<div class="inside">
<div class="title">Sistem Kedisiplinan</div>
<div class="title">Sistem Bantuan Sosial Tunai </div>
<!-- /.title -->
<div class="frm-title">Dinas Pariwisata Dan Kebudayaan Kabupaten Mamuju Tengah </div>
<div class="frm-title">Dinas Sosial, Pariwisata dan Kebudayaan Kabupaten Pinrang </div>
<!-- /.frm-title -->
<div class="frm-input"><input type="text" placeholder="Username" class="frm-inp" id="username" required><i class="fa fa-user frm-ico"></i></div>
<!-- /.frm-input -->
@ -107,19 +107,19 @@
block_ui("Sedang Login");
},
success: function(response) {
$.unblockUI();
swal({
title: "Success",
text: "Anda Berhasil Login",
icon: "success",
buttons: {
cancel: false,
confirm: false,
},
timer: 2000
// dangerMode: true,
})
delay(1500)
// $.unblockUI();
// swal({
// title: "Success",
// text: "Anda Berhasil Login",
// icon: "success",
// buttons: {
// cancel: false,
// confirm: false,
// },
// timer: 2000
// // dangerMode: true,
// })
// delay(1500)
window.location.replace(server_url + "admin")
// console.log(response)
},

View File

@ -1,10 +1,11 @@
// get the http url
var url = window.location.href;
// console.log(url)
var server_url = url;
var server_url_api = server_url + "api/";
// var server_url = "http://192.168.218.237/absensi_server/";
// var server_url_api = "http://192.168.218.237/absensi_server/api/";
// var server_url = url;
// var server_url_api = server_url + "api/";
var server_url = "http://127.0.0.1/coba/";
var server_url_api = "http://127.0.0.1/coba/api/";
console.log(server_url, server_url_api)
const delay = ms => new Promise(res => setTimeout(res, ms));