diff --git a/app/Exports/LaporanPenilaiJaminanExport.php b/app/Exports/LaporanPenilaiJaminanExport.php new file mode 100644 index 0000000..64e8165 --- /dev/null +++ b/app/Exports/LaporanPenilaiJaminanExport.php @@ -0,0 +1,128 @@ +tanggalAwal = $tanggalAwal; + $this->tanggalAkhir = $tanggalAkhir; + $this->status = $status; + $this->selectedIds = $selectedIds; + } + + + public function query() + { + $query = Permohonan::query() + ->with(['user', 'debiture', 'branch', 'tujuanPenilaian', 'penilaian', 'dokumenjaminan.jenisJaminan','nilaiPlafond', 'penilai']); + + // Filter by date range if provided + if ($this->tanggalAwal && $this->tanggalAkhir) { + $query->whereBetween('tanggal_permohonan', [$this->tanggalAwal, $this->tanggalAkhir]); + } + + $query->where('status', 'done'); + // Filter by status if provided + if ($this->status) { + $types = is_array($this->status) ? $this->status : [$this->status]; + $query->whereHas('penilai', function (Builder $query) use ($types) { + $query->whereIn('type_penilai', $types); + }); + } + + + // Filter by selected IDs if provided + if ($this->selectedIds) { + $selectedIds = is_array($this->selectedIds) ? $this->selectedIds : explode(',', $this->selectedIds); + $query->whereIn('id', $selectedIds); + } + + return $query; + } + + + public function map($row): array + { + $fieldPenilai = ['sederhana', 'standar', 'resume', 'memo', 'rap', 'call-report']; + $penilaiCek = null; + + // Find the first available field in the array + foreach ($fieldPenilai as $value) { + if (!empty($row->penilai->$value)) { + $penilaiCek = $row->penilai->$value; + break; + } + } + + $decodePenilai = json_decode($penilaiCek, true) ?? []; + + return [ + $row->id, + $row->nomor_registrasi, + $row->user->name, + $row->branch->name, + $row->tujuanPenilaian->name, + $row->debiture->name, + $row->penilai->type_penilai ?? '-', + '-', + $decodePenilai['luas_tanah'] ?? 0, + $decodePenilai['luas_bangunan'] ?? 0, + $decodePenilai['nilai_tanah_1'] ?? 0, + $decodePenilai['nilai_bangunan_1'] ?? 0, + $decodePenilai['total_nilai_pasar_wajar'] ?? 0, + $decodePenilai['likuidasi'] ?? 0, + $row->authorized_at, + $row->authorized_status ?? '-', + $row->authorized_by ?? '-', + $row->created_at, + ]; + } + + public function headings(): array + { + return [ + 'ID', + 'Nomor Registrasi', + 'User Pemohon', + 'Branch Pemohon', + 'Tujuan Penilaian', + 'Debitur', + 'Jenis Laporan', + 'Lokasi Jaminan', + 'Luas Tanah', + 'Luas Bangunan', + 'Harga Tanah', + 'Harga Bangunan', + 'Nilai Pasar Wajar', + 'Likuidasi', + 'Tanggal Laporan', + 'Nama Penilai', + 'Nik Penilai', + ]; + } + public function columnFormats(): array + { + return [ + 'A' => NumberFormat::FORMAT_NUMBER, + 'C' => NumberFormat::FORMAT_DATE_DATETIME, + 'K' => NumberFormat::FORMAT_DATE_DATETIME, + 'N' => NumberFormat::FORMAT_DATE_DATETIME + ]; + } +} diff --git a/app/Http/Controllers/LaporanPenilaiJaminanController.php b/app/Http/Controllers/LaporanPenilaiJaminanController.php new file mode 100644 index 0000000..6b7fc66 --- /dev/null +++ b/app/Http/Controllers/LaporanPenilaiJaminanController.php @@ -0,0 +1,192 @@ +user(); + + + // Check permissions + if (is_null($this->user) || !$this->user->can('debitur.view')) { + // abort(403, 'Sorry! You are not allowed to view users.'); + } + + $userRole = $user->roles->pluck('name')->first(); + $regionId = null; + + // If user is senior-officer, get their regionId + if ($userRole === 'senior-officer') { + $userTeam = TeamsUsers::with('team')->firstWhere('user_id', $user->id); + $regionId = $userTeam?->team->regions_id; + } + + // Retrieve data from the database + $query = Permohonan::query(); + + // Apply search filter if provided + if ($request->has('search') && !empty($request->get('search'))) { + $search = $request->get('search'); + $query->where(function ($q) use ($search) { + $q->where('nomor_registrasi', 'LIKE', '%' . $search . '%') + ->orWhere('tanggal_permohonan', 'LIKE', '%' . $search . '%') + ->orWhereRelation('user', 'name', 'LIKE', '%' . $search . '%') + ->orWhereRelation('debiture', 'name', 'LIKE', '%' . $search . '%') + ->orWhereRelation('tujuanPenilaian', 'name', 'LIKE', '%' . $search . '%') + ->orWhereRelation('branch', 'name', 'LIKE', '%' . $search . '%'); + + // Split search term by comma to allow multiple statuses + $statusKeywords = explode(',', $search); + foreach ($statusKeywords as $keyword) { + $q->orWhere('status', 'LIKE', '%' . trim($keyword) . '%'); + } + }); + } + $query->where('status', 'done'); + + + + // Default sorting if no sort provided + if ($request->has('sortOrder') && !empty($request->get('sortOrder'))) { + $order = $request->get('sortOrder'); + $column = $request->get('sortField'); + $query->orderBy($column, $order); + } else { + $query->orderBy('nomor_registrasi', 'asc'); + } + + // Get total count of records before pagination + $totalRecords = $query->count(); + + // Pagination + if ($request->has('page') && $request->has('size')) { + $page = (int) $request->get('page', 1); + $size = (int) $request->get('size', 10); + $offset = ($page - 1) * $size; + $query->skip($offset)->take($size); + } + + // Get filtered count + $filteredRecords = $query->count(); + + + + $totalRecords = $query->count(); + + // Pagination + if ($request->has('page') && $request->has('size')) { + $page = (int) $request->get('page', 1); + $size = (int) $request->get('size', 10); + $offset = ($page - 1) * $size; + $query->skip($offset)->take($size); + } + + // Get filtered count + $filteredRecords = $query->count(); + + // Get data with necessary relationships + $data = $query->with(['user', 'debiture', 'branch', 'tujuanPenilaian', 'penilaian', 'dokumenjaminan.jenisJaminan','nilaiPlafond', 'penilai'])->get(); + + // Calculate total pages + $pageCount = ceil($totalRecords / $request->get('size', 10)); + + + + + // Calculate total pages + $pageCount = ceil($totalRecords / $request->get('size', 10)); + + return response()->json([ + 'draw' => $request->get('draw'), + 'recordsTotal' => $totalRecords, + 'recordsFiltered' => $filteredRecords, + 'pageCount' => $pageCount, + 'page' => $request->get('page', 1), + 'totalCount' => $totalRecords, + 'data' => $data, + ]); + } + + public function export(Request $request) + { + $tanggalAwal = $request->input('tanggal_awal'); + $tanggalAkhir = $request->input('tanggal_akhir'); + $status = $request->input('status'); + $selectedIds = $request->input('selected_ids'); + + $filename = 'laporan_penilai_jaminan_' . date('YmdHis') . '.xlsx'; + return Excel::download( + new LaporanPenilaiJaminanExport($tanggalAwal, $tanggalAkhir, $status, $selectedIds), + $filename + ); + } +} diff --git a/module.json b/module.json index bf2313a..cec0301 100644 --- a/module.json +++ b/module.json @@ -377,6 +377,23 @@ "EO Appraisal", "senior-officer" ] + }, + { + "title": "Laporan Penilai Jaminan", + "path": "laporan-penilai-jaminan", + "icon": "ki-filled ki-filter-tablet text-lg text-primary", + "classes": "", + "attributes": [], + "permission": "", + "roles": [ + "administrator", + "pemohon-ao", + "pemohon-eo", + "admin", + "DD Appraisal", + "EO Appraisal", + "senior-officer" + ] } ], "master": [ diff --git a/resources/views/laporan-penilai-jaminan/index.blade.php b/resources/views/laporan-penilai-jaminan/index.blade.php new file mode 100644 index 0000000..bdf6683 --- /dev/null +++ b/resources/views/laporan-penilai-jaminan/index.blade.php @@ -0,0 +1,410 @@ +@extends('layouts.main') + +@section('breadcrumbs') + {{ Breadcrumbs::render('laporan-penilai-jaminan') }} +@endsection + +@section('content') +@push('styles') + +@endpush +
| + + | ++ Nomor Registrasi + + + | ++ User Pemohon + + + | ++ Debitur + + + | ++ Tujuan Penilaian + + + | ++ Jenis Jaminan + + + | ++ Laporan + + + | + +
|---|