diff --git a/.env.prod b/.env.prod new file mode 100644 index 0000000..1b25fbd --- /dev/null +++ b/.env.prod @@ -0,0 +1,89 @@ +APP_NAME=Laravel +APP_ENV=local +APP_KEY=base64:ysLF8NLAMjYCH7ikOgmCRATlMb6YT+8oFpAz0aJampI= +APP_DEBUG=true +APP_TIMEZONE=UTC +APP_URL=http://localhost + +APP_LOCALE=en +APP_FALLBACK_LOCALE=en +APP_FAKER_LOCALE=en_US + +APP_MAINTENANCE_DRIVER=file +# APP_MAINTENANCE_STORE=database + +PHP_CLI_SERVER_WORKERS=4 + +BCRYPT_ROUNDS=12 + +LOG_CHANNEL=stack +LOG_STACK=single +LOG_DEPRECATIONS_CHANNEL=null +LOG_LEVEL=debug + +DB_CONNECTION=pgsql +DB_HOST=172.16.88.22 +DB_PORT=5432 +DB_DATABASE=lms_mutu +DB_USERNAME=simrs +DB_PASSWORD=@S1mrs.3205@ + +DB_CONNECTION_LMS_MUTU= pgsql +DB_HOST_LMS_MUTU = 172.16.88.22 +DB_PORT_LMS_MUTU = 5432 +DB_DATABASE_LMS_MUTU = lms_mutu +DB_USERNAME_LMS_MUTU = simrs +DB_PASSWORD_LMS_MUTU = @S1mrs.3205@ + +SESSION_DRIVER=file +SESSION_LIFETIME=120 +SESSION_ENCRYPT=false +SESSION_PATH=/ +SESSION_DOMAIN=null + +BROADCAST_CONNECTION=log +FILESYSTEM_DISK=local +QUEUE_CONNECTION=database + +CACHE_STORE=database +CACHE_PREFIX= + +MEMCACHED_HOST=127.0.0.1 + +REDIS_CLIENT=phpredis +REDIS_HOST=127.0.0.1 +REDIS_PASSWORD=null +REDIS_PORT=6379 + +MAIL_MAILER=log +MAIL_SCHEME=null +MAIL_HOST=127.0.0.1 +MAIL_PORT=2525 +MAIL_USERNAME=null +MAIL_PASSWORD=null +MAIL_FROM_ADDRESS="hello@example.com" +MAIL_FROM_NAME="${APP_NAME}" + +AWS_ACCESS_KEY_ID= +AWS_SECRET_ACCESS_KEY= +AWS_DEFAULT_REGION=us-east-1 +AWS_BUCKET= +AWS_USE_PATH_STYLE_ENDPOINT=false + +VITE_APP_NAME="${APP_NAME}" + +DB_CONNECTION_SMARTV1 = pgsql +DB_HOST_SMARTV1 = psql1.rsabhk.lan +DB_PORT_SMARTV1 = 5432 +DB_DATABASE_SMARTV1 = rsab_hk_production +DB_USERNAME_SMARTV1 = postgres +DB_PASSWORD_SMARTV1 = postgres + +APP_ASSET_URL=https://survei-mutu.rsabhk.co.id/ + +# DB_CONNECTION_SMARTV1 = pgsql +# DB_HOST_SMARTV1 = 192.168.12.3 +# DB_PORT_SMARTV1 = 5432 +# DB_DATABASE_SMARTV1 = rsab_hk_25_01_14 +# DB_USERNAME_SMARTV1 = postgres +# DB_PASSWORD_SMARTV1 = postgres \ No newline at end of file diff --git a/app/Http/Controllers/AdminController.php b/app/Http/Controllers/AdminController.php index 1d8fdbf..644237d 100644 --- a/app/Http/Controllers/AdminController.php +++ b/app/Http/Controllers/AdminController.php @@ -9,6 +9,7 @@ use App\Exports\DashboardJawabanExport; use App\Models\Jawaban; use App\Models\JawabanDetail; use App\Models\SoalDetail; +use App\Models\UnitKerja; use Illuminate\Http\Request; use Illuminate\Support\Facades\DB; use Maatwebsite\Excel\Facades\Excel; @@ -77,88 +78,23 @@ class AdminController extends Controller return view('admin.dashboard', $data); } - 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" - ]; - $query = Jawaban::query() - ->select([ - 'unit', - DB::raw('COUNT(*) as total_unit'), - ])->whereNotNull('unit'); + 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"]; - - if ($request->unit_kerja) { + $query = Jawaban::query() ->select([ 'unit', DB::raw('COUNT(*) as total_unit'), ])->whereNotNull('unit'); + + if ($request->unit_kerja) { $query->whereIn('unit', (array) $request->unit_kerja); $masterUnits = array_intersect($masterUnits, $request->unit_kerja); } - $query->groupBy('unit'); + $query->groupBy('unit') ->havingRaw('COUNT(*) > 0'); $rekap = $query->get()->pluck('total_unit', 'unit'); - - $data = collect($masterUnits)->map(function ($unit) use ($rekap) { - return [ - 'unit' => $unit, - 'total_unit' => $rekap[$unit] ?? 0, - ]; - }); - + $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); - } + + public function download_report_data_pegawai_sudah_survey(Request $request) { $masterUnits = [ @@ -259,7 +195,7 @@ class AdminController extends Controller ->where('a.lms_mutu_soal_detail_id', 51) ->where('a.jawaban', 'TIDAK') ->count(); - + return response()->json([ 'msg' => 'Berhasil', 'data' => $total_tidak @@ -448,7 +384,7 @@ class AdminController extends Controller if(count($soal_json['options']) > 0){ foreach ($soal_json['options'] as $v) { - if($v != 'Lainnya'){ + if($v != 'Tidak Berlaku/Tidak Tahu, Sebutkan Alasan'){ $row = (clone $result)->where('d.jawaban', $v) ->first(); @@ -501,7 +437,7 @@ class AdminController extends Controller // foreach ($get_data as $val) { if($get_data){ $data_per_jawaban = [ - 'name' => 'Lainnya', + 'name' => 'Tidak Berlaku/Tidak Tahu, Sebutkan Alasan', 'percent' => (float) $get_data->percent, 'value' => $get_data->total_jawaban, 'total' => $get_data->total_semua, @@ -509,7 +445,7 @@ class AdminController extends Controller ]; } else { $data_per_jawaban = [ - 'name' => 'Lainnya', + 'name' => 'Tidak Berlaku/Tidak Tahu, Sebutkan Alasan', 'percent' => 0, 'value' => 0, 'jawaban' => '-' @@ -628,7 +564,7 @@ class AdminController extends Controller if(count($soal_json['options']) > 0){ foreach ($soal_json['options'] as $v) { - if($v != 'Lainnya'){ + if($v != 'Tidak Berlaku/Tidak Tahu, Sebutkan Alasan'){ $row = (clone $result)->where('d.jawaban', $v) ->first(); @@ -680,7 +616,7 @@ class AdminController extends Controller // foreach ($get_data as $val) { if($get_data){ $data_per_jawaban = [ - 'name' => 'Lainnya', + 'name' => 'Tidak Berlaku/Tidak Tahu, Sebutkan Alasan', 'percent' => (float) $get_data->percent, 'value' => $get_data->total_jawaban, 'total' => $get_data->total_semua, @@ -688,7 +624,7 @@ class AdminController extends Controller ]; } else { $data_per_jawaban = [ - 'name' => 'Lainnya', + 'name' => 'Tidak Berlaku/Tidak Tahu, Sebutkan Alasan', 'percent' => 0, 'value' => 0, 'jawaban' => '-' @@ -743,14 +679,14 @@ class AdminController extends Controller $data[$v['name']] = '-'; } - if($v['name'] == 'Lainnya') { - $data['jawaban_lainnya'] = $v['jawaban']; - } + // if($v['name'] == 'Tidak Berlaku/Tidak Tahu, Sebutkan Alasan') { + // $data['jawaban_lainnya'] = $v['jawaban']; + // } } $data['total'] = $total; array_push($data_setuju_report, $data); } - array_push($data_setuju_header, 'Jawaban Lainnya'); + // array_push($data_setuju_header, 'Jawaban Lainnya'); array_push($data_setuju_header, 'Total Responden'); array_unshift($data_setuju_report, $data_setuju_header); @@ -790,14 +726,14 @@ class AdminController extends Controller $data_selalu[$v['name']] = '-'; } - if($v['name'] == 'Lainnya') { - $data_selalu['jawaban_lainnya'] = $v['jawaban']; - } + // if($v['name'] == 'Tidak Berlaku/Tidak Tahu, Sebutkan Alasan') { + // $data_selalu['jawaban_lainnya'] = $v['jawaban']; + // } } $data_selalu['total'] = $total; array_push($data_selalu_report, $data_selalu); } - array_push($data_selalu_header, 'Jawaban Lainnya'); + // array_push($data_selalu_header, 'Jawaban Lainnya'); array_push($data_selalu_header, 'Total Responden'); array_unshift($data_selalu_report, $data_selalu_header); @@ -877,7 +813,7 @@ class AdminController extends Controller } - + public function get_data_pegawai_jawaban(Request $request) { $query = Jawaban::query(); @@ -891,6 +827,9 @@ class AdminController extends Controller } return DataTables::of($query) + ->addColumn('nama_pegawai', function($row){ + return $row?->pegawai?->nama ?? '-'; + }) ->addColumn('action', function ($row) { return ' -
-
Login Survey Mutu
- + + @csrf +
+
Login Survey Mutu
@@ -36,11 +37,11 @@
- -
-
- -
+ +
+ +
+ @endsection diff --git a/resources/views/layouts/template.blade.php b/resources/views/layouts/template.blade.php index deb9f1f..bdd7c15 100644 --- a/resources/views/layouts/template.blade.php +++ b/resources/views/layouts/template.blade.php @@ -8,7 +8,7 @@ @yield('title', 'Survey Mutu RSAB Harapan Kita') - + @@ -18,29 +18,29 @@ rel="stylesheet"> - - + + - - + + - - - - - - + + + + + + - + - + @yield('custom_css') @@ -48,8 +48,8 @@ @@ -59,20 +59,20 @@ - - - - - - - - + + + + + + + + - + - + + - +