Compare commits
No commits in common. "34776eb33a94b00234112e6c4f8d140fbe45e67b" and "b39bf4d6660818e63e7289e3cc6adf1676861ae2" have entirely different histories.
34776eb33a
...
b39bf4d666
@ -9,7 +9,6 @@ use App\Exports\DashboardJawabanExport;
|
|||||||
use App\Models\Jawaban;
|
use App\Models\Jawaban;
|
||||||
use App\Models\JawabanDetail;
|
use App\Models\JawabanDetail;
|
||||||
use App\Models\SoalDetail;
|
use App\Models\SoalDetail;
|
||||||
use App\Models\UnitKerja;
|
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Support\Facades\DB;
|
use Illuminate\Support\Facades\DB;
|
||||||
use Maatwebsite\Excel\Facades\Excel;
|
use Maatwebsite\Excel\Facades\Excel;
|
||||||
@ -78,23 +77,90 @@ class AdminController extends Controller
|
|||||||
return view('admin.dashboard', $data);
|
return view('admin.dashboard', $data);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function get_data_pegawai_sudah_survey(Request $request) {
|
public function get_data_pegawai_sudah_survey(Request $request)
|
||||||
$masterUnits = ["Direktur Utama dan Direksi", "Satuan Pengawas Internal", "Komite Mutu", "Komite Medik", "Komite Keperawatan", "Komite PPI & PRA", "KTKL", "KFT", "KEH", "ULP", "Timker Yankep", "Timker Yanjang", "Timker Perencanaan, Evaluasi dan Program", "Timker Hukum dan Humas", "Timker Yanmed", "Timker Perencanaan dan Evaluasi Anggaran", "Timker Akutansi dan BMN", "Timker Organisasi dan Sumber Daya Manusia", "Timker TU & RT", "Timker Diklat", "Timker Penelitian", "Timker Pelaksanan Keuangan", "Instalasi Rawat Inap", "Instalasi Rawat Jalan Reguler", "Instalasi Rawat Intensif / ICU", "Instalasi Rehabilitasi Medik", "Instalasi Gizi", "Instalasi Laboratorium Terpadu", "Instalasi Sistem Informasi Manajemen Rumah Sakit (SIMRS)", "Instalasi Bedah Sentral", "Instalasi Radiologi", "Instalasi Farmasi", "Instalasi Rekam Medis", "Instalasi Gawat Darurat", "Instalasi Verifikasi dan Penjaminan Pasien", "Instalasi KL & K3RS", "ISSB", "IPT", "IPJNI", "IPSPRS", "IPPB", "IPPISGB", "Instalasi Rawat Jalan Eksekutif", "Instalasi Teknologi Berbantu (TRB)", "Klinik Utama Bintaro", "KSM Anak", "KSM Obstetri & Ginekologi", "KSM Bedah", "KSM Anestesi", "KSM Gigi & Mulut", "KSM Spesialis Lain", "KSM Umum", "Lainnya"];
|
{
|
||||||
|
$masterUnits = [
|
||||||
|
"Direktur Utama dan Direksi",
|
||||||
|
"Satuan Pengawas Internal",
|
||||||
|
"Komite Mutu",
|
||||||
|
"Komite Medik",
|
||||||
|
"Komite Keperawatan",
|
||||||
|
"Komite PPI & PRA",
|
||||||
|
"KTKL",
|
||||||
|
"KFT",
|
||||||
|
"KEH",
|
||||||
|
"ULP",
|
||||||
|
"Timker Yankep",
|
||||||
|
"Timker Yanjang",
|
||||||
|
"Timker Perencanaan, Evaluasi dan Program",
|
||||||
|
"Timker Hukum dan Humas",
|
||||||
|
"Timker Yanmed",
|
||||||
|
"Timker Perencanaan dan Evaluasi Anggaran",
|
||||||
|
"Timker Akutansi dan BMN",
|
||||||
|
"Timker Organisasi dan Sumber Daya Manusia",
|
||||||
|
"Timker TU & RT",
|
||||||
|
"Timker Diklat",
|
||||||
|
"Timker Penelitian",
|
||||||
|
"Timker Pelaksanan Keuangan",
|
||||||
|
"Instalasi Rawat Inap",
|
||||||
|
"Instalasi Rawat Jalan Reguler",
|
||||||
|
"Instalasi Rawat Intensif / ICU",
|
||||||
|
"Instalasi Rehabilitasi Medik",
|
||||||
|
"Instalasi Gizi",
|
||||||
|
"Instalasi Laboratorium Terpadu",
|
||||||
|
"Instalasi Sistem Informasi Manajemen Rumah Sakit (SIMRS)",
|
||||||
|
"Instalasi Bedah Sentral",
|
||||||
|
"Instalasi Radiologi",
|
||||||
|
"Instalasi Farmasi",
|
||||||
|
"Instalasi Rekam Medis",
|
||||||
|
"Instalasi Gawat Darurat",
|
||||||
|
"Instalasi Verifikasi dan Penjaminan Pasien",
|
||||||
|
"Instalasi KL & K3RS",
|
||||||
|
"ISSB",
|
||||||
|
"IPT",
|
||||||
|
"IPJNI",
|
||||||
|
"IPSPRS",
|
||||||
|
"IPPB",
|
||||||
|
"IPPISGB",
|
||||||
|
"Instalasi Rawat Jalan Eksekutif",
|
||||||
|
"Instalasi Teknologi Berbantu (TRB)",
|
||||||
|
"Klinik Utama Bintaro",
|
||||||
|
"KSM Anak",
|
||||||
|
"KSM Obstetri & Ginekologi",
|
||||||
|
"KSM Bedah",
|
||||||
|
"KSM Anestesi",
|
||||||
|
"KSM Gigi & Mulut",
|
||||||
|
"KSM Spesialis Lain",
|
||||||
|
"KSM Umum",
|
||||||
|
"Lainnya"
|
||||||
|
];
|
||||||
|
$query = Jawaban::query()
|
||||||
|
->select([
|
||||||
|
'unit',
|
||||||
|
DB::raw('COUNT(*) as total_unit'),
|
||||||
|
])->whereNotNull('unit');
|
||||||
|
|
||||||
$query = Jawaban::query() ->select([ 'unit', DB::raw('COUNT(*) as total_unit'), ])->whereNotNull('unit');
|
|
||||||
|
|
||||||
if ($request->unit_kerja) {
|
if ($request->unit_kerja) {
|
||||||
$query->whereIn('unit', (array) $request->unit_kerja);
|
$query->whereIn('unit', (array) $request->unit_kerja);
|
||||||
$masterUnits = array_intersect($masterUnits, $request->unit_kerja);
|
$masterUnits = array_intersect($masterUnits, $request->unit_kerja);
|
||||||
}
|
}
|
||||||
$query->groupBy('unit') ->havingRaw('COUNT(*) > 0');
|
$query->groupBy('unit')
|
||||||
|
->havingRaw('COUNT(*) > 0');
|
||||||
$rekap = $query->get()->pluck('total_unit', 'unit');
|
$rekap = $query->get()->pluck('total_unit', 'unit');
|
||||||
$data = collect($masterUnits)->filter(fn($unit) => ($rekap[$unit] ?? 0) > 0)->map(fn($unit) => [ 'unit' => $unit, 'total_unit' => $rekap[$unit], ])->values();
|
|
||||||
|
$data = collect($masterUnits)
|
||||||
|
->filter(fn($unit) => ($rekap[$unit] ?? 0) > 0)
|
||||||
|
->map(fn($unit) => [
|
||||||
|
'unit' => $unit,
|
||||||
|
'total_unit' => $rekap[$unit],
|
||||||
|
])
|
||||||
|
->values();
|
||||||
|
|
||||||
return DataTables::of($data)->make(true);
|
return DataTables::of($data)->make(true);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public function download_report_data_pegawai_sudah_survey(Request $request)
|
public function download_report_data_pegawai_sudah_survey(Request $request)
|
||||||
{
|
{
|
||||||
$masterUnits = [
|
$masterUnits = [
|
||||||
@ -827,9 +893,6 @@ class AdminController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
return DataTables::of($query)
|
return DataTables::of($query)
|
||||||
->addColumn('nama_pegawai', function($row){
|
|
||||||
return $row?->pegawai?->nama ?? '-';
|
|
||||||
})
|
|
||||||
->addColumn('action', function ($row) {
|
->addColumn('action', function ($row) {
|
||||||
return '
|
return '
|
||||||
<button type="button" class="btn btn-primary" data-bs-toggle="modal" data-bs-target="#detail_jawaban" data-id="'. $row->id .'">
|
<button type="button" class="btn btn-primary" data-bs-toggle="modal" data-bs-target="#detail_jawaban" data-id="'. $row->id .'">
|
||||||
|
|||||||
@ -244,8 +244,6 @@ class SoalController extends Controller
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return redirect()->route('soal.thankyou')
|
return redirect()->route('soal.thankyou')
|
||||||
->with('success', 'Jawaban berhasil disimpan.');
|
->with('success', 'Jawaban berhasil disimpan.');
|
||||||
}
|
}
|
||||||
|
|||||||
@ -9,15 +9,11 @@ class Jawaban extends Model
|
|||||||
protected $connection = 'dbLmsMutu';
|
protected $connection = 'dbLmsMutu';
|
||||||
protected $table = 'public.lms_mutu_jawaban';
|
protected $table = 'public.lms_mutu_jawaban';
|
||||||
protected $guarded = ['id'];
|
protected $guarded = ['id'];
|
||||||
protected $with = ['jawabanDetail', 'pegawai'];
|
protected $with = ['jawabanDetail'];
|
||||||
|
|
||||||
public $timestamps = false;
|
public $timestamps = false;
|
||||||
|
|
||||||
public function jawabanDetail(){
|
public function jawabanDetail(){
|
||||||
return $this->hasMany(JawabanDetail::class, 'lms_mutu_jawaban_id', 'id');
|
return $this->hasMany(JawabanDetail::class, 'lms_mutu_jawaban_id', 'id');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function pegawai(){
|
|
||||||
return $this->belongsTo(Pegawai::class, 'pegawai_id', 'id');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,18 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Models;
|
|
||||||
|
|
||||||
use Illuminate\Database\Eloquent\Model;
|
|
||||||
|
|
||||||
class MappingUnitPegawai extends Model
|
|
||||||
{
|
|
||||||
protected $connection = 'dbSmartv1'; // nama connection di config/database.php
|
|
||||||
protected $table = 'mappegawaijabatantounitkerja_m'; // atau 'public.pegawai_m' kalau pakai schema
|
|
||||||
protected $primaryKey = 'id';
|
|
||||||
protected $with = ['pegawai'];
|
|
||||||
|
|
||||||
public function pegawai(){
|
|
||||||
return $this->belongsTo(Pegawai::class, 'objectpegawaifk', 'id');
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@ -1,15 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Models;
|
|
||||||
|
|
||||||
use Illuminate\Database\Eloquent\Model;
|
|
||||||
|
|
||||||
class Pegawai extends Model
|
|
||||||
{
|
|
||||||
protected $connection = 'dbSmartv1'; // nama connection di config/database.php
|
|
||||||
protected $table = 'pegawai_m'; // atau 'public.pegawai_m' kalau pakai schema
|
|
||||||
protected $primaryKey = 'id';
|
|
||||||
public $timestamps = false;
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
@ -1,18 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Models;
|
|
||||||
|
|
||||||
use Illuminate\Database\Eloquent\Model;
|
|
||||||
|
|
||||||
class UnitKerja extends Model
|
|
||||||
{
|
|
||||||
protected $connection = 'dbSmartv1'; // nama connection di config/database.php
|
|
||||||
protected $table = 'unitkerjapegawai_m'; // atau 'public.pegawai_m' kalau pakai schema
|
|
||||||
protected $primaryKey = 'id';
|
|
||||||
protected $with = ['mappingPegawai'];
|
|
||||||
|
|
||||||
public function mappingPegawai(){
|
|
||||||
return $this->hasMany(MappingUnitPegawai::class, 'objectunitkerjapegawaifk', 'id');
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@ -44,7 +44,6 @@
|
|||||||
<thead class="bg-primary" id="table_header">
|
<thead class="bg-primary" id="table_header">
|
||||||
<tr>
|
<tr>
|
||||||
<th class="text-white fs-5">Nama Pegawai</th>
|
<th class="text-white fs-5">Nama Pegawai</th>
|
||||||
<th class="text-white fs-5">Inisial Pegawai</th>
|
|
||||||
<th class="text-white fs-5">Unit Kerja</th>
|
<th class="text-white fs-5">Unit Kerja</th>
|
||||||
<th class="text-white fs-5">Action</th>
|
<th class="text-white fs-5">Action</th>
|
||||||
</tr>
|
</tr>
|
||||||
@ -116,7 +115,6 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
columns: [
|
columns: [
|
||||||
{ data: 'nama_pegawai' },
|
|
||||||
{ data: 'nama' },
|
{ data: 'nama' },
|
||||||
{ data: 'unit' },
|
{ data: 'unit' },
|
||||||
{ data: 'action' }
|
{ data: 'action' }
|
||||||
|
|||||||
@ -17,7 +17,7 @@ Route::middleware('ceklogin')->group(function () {
|
|||||||
Route::get('/admin', [AdminController::class, 'index']);
|
Route::get('/admin', [AdminController::class, 'index']);
|
||||||
Route::post('/admin/get_data_pegawai_sudah_survey', [AdminController::class, 'get_data_pegawai_sudah_survey']);
|
Route::post('/admin/get_data_pegawai_sudah_survey', [AdminController::class, 'get_data_pegawai_sudah_survey']);
|
||||||
Route::post('/admin/get_data_pegawai_tidak_mau_survey', [AdminController::class, 'data_tidak_mau_survey']);
|
Route::post('/admin/get_data_pegawai_tidak_mau_survey', [AdminController::class, 'data_tidak_mau_survey']);
|
||||||
// Route::get('/admin/dashboard_jawaban', [AdminController::class, 'dashboard_analisis']);
|
Route::get('/admin/dashboard_jawaban', [AdminController::class, 'dashboard_analisis']);
|
||||||
Route::post('/admin/get_data_dashboard_jawaban', [AdminController::class, 'get_data_dashboard_analisis']);
|
Route::post('/admin/get_data_dashboard_jawaban', [AdminController::class, 'get_data_dashboard_analisis']);
|
||||||
Route::post('/admin/report', [AdminController::class, 'download_report_data_pegawai_sudah_survey']);
|
Route::post('/admin/report', [AdminController::class, 'download_report_data_pegawai_sudah_survey']);
|
||||||
Route::get('/admin/dashboard_analisis', [AdminController::class, 'dashboard_analisis']);
|
Route::get('/admin/dashboard_analisis', [AdminController::class, 'dashboard_analisis']);
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user