Merge remote-tracking branch 'composer/feature/senior-officer' into staging
This commit is contained in:
36
app/Http/Controllers/DashboardController.php
Normal file
36
app/Http/Controllers/DashboardController.php
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Http\Controllers;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Modules\Lpj\Services\DashboardService;
|
||||||
|
|
||||||
|
class DashboardController extends Controller
|
||||||
|
{
|
||||||
|
public $dashboardService;
|
||||||
|
public function __construct(DashboardService $dashboardService)
|
||||||
|
{
|
||||||
|
$this->dashboardService = $dashboardService;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Display a listing of the resource.
|
||||||
|
*/
|
||||||
|
public function index(Request $request)
|
||||||
|
{
|
||||||
|
// nilai default
|
||||||
|
$start_date = $request->input('start_date', now()->startOfYear()->format('Y-m-d'));
|
||||||
|
$end_date = $request->input('end_date', now()->format('Y-m-d'));
|
||||||
|
|
||||||
|
$validate = $request->validate([
|
||||||
|
'start_date' => 'nullable|date_format:Y-m-d',
|
||||||
|
'end_date' => 'nullable|date_format:Y-m-d',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$dashboard = $this->dashboardService->getDashboardData($start_date, $end_date);
|
||||||
|
|
||||||
|
// dd($dashboard);
|
||||||
|
return view('lpj::dashboard.index', compact('dashboard'));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,23 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Http\Controllers;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
|
||||||
|
class LaporanBiayaInternalExternalController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Display a listing of the resource.
|
||||||
|
*/
|
||||||
|
public function showLaporanBiayaInternal()
|
||||||
|
{
|
||||||
|
return view('lpj::laporan-biaya.internal');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function showLaporanBiayaExternal()
|
||||||
|
{
|
||||||
|
return view('lpj::laporan-biaya.external');
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
33
app/Http/Controllers/LaporanDebitureController.php
Normal file
33
app/Http/Controllers/LaporanDebitureController.php
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Http\Controllers;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Modules\Lpj\Models\Debiture;
|
||||||
|
use Modules\Lpj\Services\LaporanDebitureService;
|
||||||
|
|
||||||
|
class LaporanDebitureController extends Controller
|
||||||
|
{
|
||||||
|
private $laporanDebitureService;
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
$this->laporanDebitureService = app(LaporanDebitureService::class);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Display a listing of the resource.
|
||||||
|
*/
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
$debiture = Debiture::all();
|
||||||
|
return view('lpj::laporan-debiture.index', compact('debiture'));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function dataTableForDebiture(Request $request)
|
||||||
|
{
|
||||||
|
return $this->laporanDebitureService->dataForDatatables($request);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
43
app/Http/Controllers/LaporanMonitoringSoController.php
Normal file
43
app/Http/Controllers/LaporanMonitoringSoController.php
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Http\Controllers;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Modules\Lpj\Services\LaporanMonitoringSoService;
|
||||||
|
|
||||||
|
class LaporanMonitoringSoController extends Controller
|
||||||
|
{
|
||||||
|
|
||||||
|
private $laporanMonitoringSoService;
|
||||||
|
|
||||||
|
public function __construct(LaporanMonitoringSoService $laporanMonitoringSoService)
|
||||||
|
{
|
||||||
|
$this->laporanMonitoringSoService = $laporanMonitoringSoService;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Display a listing of the resource.
|
||||||
|
*/
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
$user = auth()->user()->load('roles');
|
||||||
|
$result = $this->laporanMonitoringSoService->progresPengerjaanLaporan($user);
|
||||||
|
return view('lpj::laporan-monitoring.index', compact('result'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Show details data.
|
||||||
|
* @return Response
|
||||||
|
*/
|
||||||
|
|
||||||
|
public function show($id){
|
||||||
|
return view('lpj::laporan-monitoring.show', compact('id'));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function dataForDatatablePenilai(Request $request, $id){
|
||||||
|
return $this->laporanMonitoringSoService->showDetailsPermohonan($request, $id);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
32
app/Http/Controllers/LaporanSLAPenilaiController.php
Normal file
32
app/Http/Controllers/LaporanSLAPenilaiController.php
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Http\Controllers;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Modules\Lpj\Services\LaporanSLAPenilaiService;
|
||||||
|
|
||||||
|
class LaporanSLAPenilaiController extends Controller
|
||||||
|
{
|
||||||
|
private $laporanSLAPenilaiService;
|
||||||
|
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
$this->laporanSLAPenilaiService = app(LaporanSLAPenilaiService::class);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Display a listing of the resource.
|
||||||
|
*/
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
return view('lpj::laporan-sla-penilai.index');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function dataForDatatableSLaPenilai(Request $request)
|
||||||
|
{
|
||||||
|
return $this->laporanSLAPenilaiService->dataForDatatables($request);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
41
app/Http/Controllers/LaporanUserController.php
Normal file
41
app/Http/Controllers/LaporanUserController.php
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Http\Controllers;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Modules\Lpj\Services\LaporanUserService;
|
||||||
|
|
||||||
|
class LaporanUserController extends Controller
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
private $laporanUserService;
|
||||||
|
|
||||||
|
public function __construct(LaporanUserService $laporanUserService)
|
||||||
|
{
|
||||||
|
$this->laporanUserService = $laporanUserService;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Display a listing of the resource.
|
||||||
|
*/
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
// $user = $this->laporanUserService->getUserPemohon();
|
||||||
|
return view('lpj::laporan-user.index');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function searchUserPemohon(Request $request)
|
||||||
|
{
|
||||||
|
$search = $request->get('search');
|
||||||
|
$user = $this->laporanUserService->getUserPemohon($search);
|
||||||
|
return response()->json($user);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function dataTableForUserPemohon(Request $request)
|
||||||
|
{
|
||||||
|
return $this->laporanUserService->dataForDatatables($request);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
22
app/Http/Controllers/RekapHarianSoController.php
Normal file
22
app/Http/Controllers/RekapHarianSoController.php
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Http\Controllers;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Modules\Lpj\Models\TujuanPenilaian;
|
||||||
|
|
||||||
|
class RekapHarianSoController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Display a listing of the resource.
|
||||||
|
*/
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
$total_laporan_debitur = 0;
|
||||||
|
$tujuan_penilaian = TujuanPenilaian::all();
|
||||||
|
return view('lpj::rekap-harian-so.index', compact('tujuan_penilaian', 'total_laporan_debitur'));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
179
app/Services/DashboardService.php
Normal file
179
app/Services/DashboardService.php
Normal file
@@ -0,0 +1,179 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Services;
|
||||||
|
|
||||||
|
use Modules\Lpj\Models\Laporan;
|
||||||
|
use Modules\Lpj\Models\Noc;
|
||||||
|
use Modules\Lpj\Models\Permohonan;
|
||||||
|
use Illuminate\Support\Facades\DB;
|
||||||
|
class DashboardService
|
||||||
|
{
|
||||||
|
public function getDashboardData($start_date, $end_date)
|
||||||
|
{
|
||||||
|
$countLpjInternal = $this->getTotalLpjInternal($start_date, $end_date);
|
||||||
|
$countLpjExternal = $this->getTotalLpjEksternal($start_date, $end_date);
|
||||||
|
$countResume = $this->getResumeCabang($start_date, $end_date);
|
||||||
|
$countPendapatan = $this->getPendapatanAppraisal($start_date, $end_date);
|
||||||
|
|
||||||
|
return [
|
||||||
|
'count_lpj_internal' => $countLpjInternal,
|
||||||
|
'count_lpj_eksternal' => $countLpjExternal,
|
||||||
|
'count_resume' => $countResume,
|
||||||
|
'count_pendapatan' => $countPendapatan
|
||||||
|
];
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public function getTotalLpjInternal($start_date, $end_date)
|
||||||
|
{
|
||||||
|
$months = $this->getMonthly();
|
||||||
|
$regions = $this->getRegion();
|
||||||
|
$data = [];
|
||||||
|
|
||||||
|
foreach ($months as $index => $month) {
|
||||||
|
$monthNumber = $index + 1;
|
||||||
|
$data[$month] = [];
|
||||||
|
|
||||||
|
foreach ($regions as $region) {
|
||||||
|
if ($monthNumber > now()->month) {
|
||||||
|
|
||||||
|
$data[$month][$region] = [
|
||||||
|
'total_laporan' => 0,
|
||||||
|
'total_debiture' => 0,
|
||||||
|
];
|
||||||
|
} else {
|
||||||
|
|
||||||
|
$totalLaporan = Laporan::whereBetween('created_at', [$start_date, $end_date])
|
||||||
|
->count();
|
||||||
|
$totalDebitur = Permohonan::whereBetween('created_at', [$start_date, $end_date])
|
||||||
|
->where('status', 'done')
|
||||||
|
->distinct()
|
||||||
|
->count('debiture_id');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
$data[$month][$region] = [
|
||||||
|
'total_laporan' => $totalLaporan,
|
||||||
|
'total_debiture' => $totalDebitur,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public function getPendapatanAppraisal($start_date, $end_date)
|
||||||
|
{
|
||||||
|
$months = $this->getMonthly();
|
||||||
|
$data = [];
|
||||||
|
|
||||||
|
foreach ($months as $index => $month) {
|
||||||
|
$monthNumber = $index + 1;
|
||||||
|
|
||||||
|
if ($monthNumber > now()->month) {
|
||||||
|
// Bulan belum terjadi
|
||||||
|
$data[$month] = [
|
||||||
|
'total_jumlah' => 0,
|
||||||
|
'total_akumulasi' => 0,
|
||||||
|
];
|
||||||
|
} else {
|
||||||
|
// Hitung jumlah nominal_bayar pada bulan ini
|
||||||
|
$totalJumlah = Noc::whereYear('tanggal_pembayaran', now()->year)
|
||||||
|
->whereMonth('tanggal_pembayaran', $monthNumber)
|
||||||
|
->sum('nominal_bayar');
|
||||||
|
|
||||||
|
|
||||||
|
$data[$month] = [
|
||||||
|
'total_jumlah' => $totalJumlah,
|
||||||
|
'total_akumulasi' => $totalJumlah,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getResumeCabang($start_date, $end_date)
|
||||||
|
{
|
||||||
|
$regions = $this->getRegion();
|
||||||
|
$status = ['batal', 'done'];
|
||||||
|
$data = [];
|
||||||
|
|
||||||
|
foreach ($status as $item) {
|
||||||
|
$data[$item] = [];
|
||||||
|
foreach ($regions as $region) {
|
||||||
|
$totalLaporan = DB::table('laporan')
|
||||||
|
->join('permohonan', 'laporan.permohonan_id', '=', 'permohonan.id')
|
||||||
|
->where('permohonan.status', $item)
|
||||||
|
->whereBetween('laporan.created_at', [$start_date, $end_date])
|
||||||
|
->count();
|
||||||
|
|
||||||
|
$data[$item][$region] = [
|
||||||
|
'count_report' => $totalLaporan,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $data;
|
||||||
|
|
||||||
|
}
|
||||||
|
public function getTotalLpjEksternal($start_date, $end_date)
|
||||||
|
{
|
||||||
|
$months = $this->getMonthly();
|
||||||
|
$data = [];
|
||||||
|
foreach ($months as $index => $month) {
|
||||||
|
$monthNumber = $index + 1;
|
||||||
|
if ($monthNumber > now()->month) {
|
||||||
|
$data[$month] = [
|
||||||
|
'total_laporan' => 0,
|
||||||
|
'total_debiture' => 0,
|
||||||
|
];
|
||||||
|
} else {
|
||||||
|
$totalLaporan = Laporan::where('created_at', '>=', $start_date)->where('created_at', '<=', $end_date)->count();
|
||||||
|
|
||||||
|
$totalDebitur = Permohonan::whereBetween('created_at', [$start_date, $end_date])
|
||||||
|
->where('status', 'done')
|
||||||
|
->distinct()
|
||||||
|
->count('debiture_id');
|
||||||
|
|
||||||
|
$data[$month] = [
|
||||||
|
'total_laporan' => $totalLaporan,
|
||||||
|
'total_debiture' => $totalDebitur,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $data;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getMonthly()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'januari',
|
||||||
|
'februari',
|
||||||
|
'maret',
|
||||||
|
'april',
|
||||||
|
'mei',
|
||||||
|
'juni',
|
||||||
|
'juli',
|
||||||
|
'agustus',
|
||||||
|
'september',
|
||||||
|
'oktober',
|
||||||
|
'november',
|
||||||
|
'desember',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getRegion()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'jabodetabek',
|
||||||
|
'non-jabodetabek',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
182
app/Services/LaporanDebitureService.php
Normal file
182
app/Services/LaporanDebitureService.php
Normal file
@@ -0,0 +1,182 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Services;
|
||||||
|
use Modules\Lpj\Models\Permohonan;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
class LaporanDebitureService
|
||||||
|
{
|
||||||
|
public function dataForDatatables(Request $request)
|
||||||
|
{
|
||||||
|
|
||||||
|
// Retrieve data from the database
|
||||||
|
$query = Permohonan::query();
|
||||||
|
$query = $query->where('status', 'done');
|
||||||
|
|
||||||
|
// Apply search filter if provided
|
||||||
|
if ($request->has('search') && !empty($request->get('search'))) {
|
||||||
|
$search = json_decode($request->get('search'));
|
||||||
|
|
||||||
|
if (isset($search->start_date) || isset($search->end_date)) {
|
||||||
|
$query->whereBetween('tanggal_permohonan', [
|
||||||
|
$search->start_date ?? '1900-01-01',
|
||||||
|
$search->end_date ?? now()->toDateString()
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Filter by branch if provided
|
||||||
|
if (isset($search->debiture_id) && !empty($search->debiture_id)) {
|
||||||
|
$query->where('debiture_id', $search->debiture_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($search->search)) {
|
||||||
|
|
||||||
|
$query->where(function ($q) use ($search) {
|
||||||
|
$q->where('nomor_registrasi', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhere('tanggal_permohonan', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('user', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('tujuanPenilaian', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('branch', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('jenisFasilitasKredit', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('jenisPenilaian', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhere('status', 'LIKE', '%' . $search->search . '%');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Apply sorting if provided
|
||||||
|
if ($request->has('sortOrder') && !empty($request->get('sortOrder'))) {
|
||||||
|
$order = $request->get('sortOrder');
|
||||||
|
$column = $request->get('sortField');
|
||||||
|
$query->orderBy($column, $order);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the total count of records
|
||||||
|
$totalRecords = $query->count();
|
||||||
|
|
||||||
|
// Apply pagination if provided
|
||||||
|
if ($request->has('page') && $request->has('size')) {
|
||||||
|
$page = $request->get('page');
|
||||||
|
$size = $request->get('size');
|
||||||
|
$offset = ($page - 1) * $size; // Calculate the offset
|
||||||
|
|
||||||
|
$query->skip($offset)->take($size);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the filtered count of records
|
||||||
|
$filteredRecords = $query->count();
|
||||||
|
|
||||||
|
// Get the data for the current page
|
||||||
|
$data = $query->with(['debiture.branch'])->get();
|
||||||
|
|
||||||
|
$data = $data->map(function ($permohonan) {
|
||||||
|
$luas_tanah = 0;
|
||||||
|
$luas_bangunan = 0;
|
||||||
|
$nilai_tanah = 0;
|
||||||
|
$nilai_bangunan = 0;
|
||||||
|
$npw = 0;
|
||||||
|
$nilai_liquidasi = 0;
|
||||||
|
|
||||||
|
if (isset($permohonan->penilai->lpj)) {
|
||||||
|
$lpj = json_decode($permohonan->penilai->lpj, true);
|
||||||
|
$npw = str_replace('.', '', $lpj['total_nilai_pasar_wajar'] ?? 0);
|
||||||
|
|
||||||
|
$luas_tanah = $lpj['luas_tanah'] ?? 0;
|
||||||
|
$luas_bangunan = $lpj['luas_bangunan'] ?? 0;
|
||||||
|
// Calculate nilai_tanah dynamically by looking for all keys that start with 'nilai_tanah_'
|
||||||
|
$nilai_tanah = str_replace('.', '', $lpj['nilai_tanah_2'] ?? 0);
|
||||||
|
|
||||||
|
$nilai_bangunan = str_replace('.', '', $lpj['nilai_bangunan_2'] ?? 0);
|
||||||
|
$nilai_liquidasi = str_replace('.', '', $lpj['likuidasi_nilai_2'] ?? 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
'id' => $permohonan->id,
|
||||||
|
'nomor_registrasi' => $permohonan->nomor_registrasi,
|
||||||
|
'jenis_penilaian' => $permohonan->jenisPenilaian?->name,
|
||||||
|
'tujuan_penilaian' => $permohonan->tujuanPenilaian?->name,
|
||||||
|
'jenis_fasilitas_kredit' => $permohonan->jenisFasilitasKredit?->name,
|
||||||
|
'branch' => $permohonan->debiture->branch?->name,
|
||||||
|
'pemohon' => $permohonan->creator?->name,
|
||||||
|
'cif' => $permohonan->debiture->cif,
|
||||||
|
'name' => $permohonan->debiture?->name,
|
||||||
|
'jenis_agunan' => $permohonan->documents?->pluck('jenisJaminan.name')
|
||||||
|
->unique()
|
||||||
|
->implode(', '),
|
||||||
|
'alamat_agunan' => $permohonan->documents?->map(function ($document) {
|
||||||
|
return formatAlamat($document);
|
||||||
|
})->unique()->implode(', '),
|
||||||
|
'bukti_kepemilikan' => (function () use ($permohonan) {
|
||||||
|
$legalitasItems = $permohonan->documents?->flatMap(function ($document) {
|
||||||
|
return $document->detail->map(function ($detail) {
|
||||||
|
// Jika tidak ada jenis legalitas jaminan, lewati
|
||||||
|
if (empty($detail->jenisLegalitasJaminan)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hanya tampilkan detail yang memiliki dokumen_jaminan
|
||||||
|
if (empty($detail->dokumen_jaminan)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Tampilkan nama legalitas jaminan saja
|
||||||
|
return $detail->jenisLegalitasJaminan->name ?? '';
|
||||||
|
});
|
||||||
|
})->filter()->unique()->values()->toArray();
|
||||||
|
|
||||||
|
// Buat daftar bernomor
|
||||||
|
$result = '';
|
||||||
|
foreach ($legalitasItems as $index => $item) {
|
||||||
|
$result .= ($index + 1) . '. ' . $item . "\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
return $result;
|
||||||
|
})(),
|
||||||
|
'nama_pemilik' => $permohonan->documents?->pluck('pemilik.name')
|
||||||
|
->unique()
|
||||||
|
->implode(', '),
|
||||||
|
'luas_tanah' => $luas_tanah . ' m²',
|
||||||
|
'nilai_tanah' => formatRupiah($nilai_tanah, 2),
|
||||||
|
'luas_bangunan' => $luas_bangunan . ' m²',
|
||||||
|
'nilai_bangunan' => formatRupiah($nilai_bangunan, 2),
|
||||||
|
'nilai_njop' => formatRupiah($permohonan->nilai_njop, 2),
|
||||||
|
'nilai_pasar_wajar' => formatRupiah($npw, 2),
|
||||||
|
'nilai_likuidasi' => formatRupiah($nilai_liquidasi, 2),
|
||||||
|
'tanggal_documen_diterima' => $permohonan->documents?->map(function ($document) {
|
||||||
|
return $document->created_at->format('d-m-Y');
|
||||||
|
}),
|
||||||
|
'tanggal_spk' => '',
|
||||||
|
'nomor_spk' => '',
|
||||||
|
'tanggal_rencana_kunjunagn' => '',
|
||||||
|
'tanggal_kunjungan' => '',
|
||||||
|
'taggal_delivered' => '',
|
||||||
|
'jangka_waktu_sla' => '',
|
||||||
|
'nama_penilai' => $permohonan->penilaian?->_user_penilai?->userPenilaiTeam?->name,
|
||||||
|
'nama_team_leader' => $permohonan->penilaian?->teams,
|
||||||
|
'saran' => '',
|
||||||
|
'catatan' => '',
|
||||||
|
|
||||||
|
|
||||||
|
'tanggal_permohonan' => $permohonan->tanggal_permohonan,
|
||||||
|
'tanggal_laporan' => $permohonan->approval_dd_at ?? $permohonan->approval_eo_at ?? '',
|
||||||
|
'tanggal_review' => $permohonan->penilaian?->tanggal_kunjungan ?? '',
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
// Calculate the page count
|
||||||
|
$pageCount = ceil($totalRecords / $request->get('size'));
|
||||||
|
|
||||||
|
// Calculate the current page number
|
||||||
|
$currentPage = $request->get('page') ?: 1;
|
||||||
|
|
||||||
|
// Return the response data as a JSON object
|
||||||
|
return response()->json([
|
||||||
|
'draw' => $request->get('draw'),
|
||||||
|
'recordsTotal' => $totalRecords,
|
||||||
|
'recordsFiltered' => $filteredRecords,
|
||||||
|
'pageCount' => $pageCount,
|
||||||
|
'page' => $currentPage,
|
||||||
|
'totalCount' => $totalRecords,
|
||||||
|
'data' => $data,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
228
app/Services/LaporanMonitoringSoService.php
Normal file
228
app/Services/LaporanMonitoringSoService.php
Normal file
@@ -0,0 +1,228 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Services;
|
||||||
|
use Modules\Lpj\Models\TeamsUsers;
|
||||||
|
use Modules\Lpj\Models\Teams;
|
||||||
|
use Modules\Lpj\Models\Debiture;
|
||||||
|
use Modules\Lpj\Models\Permohonan;
|
||||||
|
use Modules\Lpj\Models\Penilaian;
|
||||||
|
use Modules\Lpj\Models\StatusPermohonan;
|
||||||
|
use Carbon\Carbon;
|
||||||
|
class LaporanMonitoringSoService
|
||||||
|
{
|
||||||
|
|
||||||
|
public function progresPengerjaanLaporan($user){
|
||||||
|
|
||||||
|
// Inisialisasi regionId dan teamId
|
||||||
|
$regionId = $teamId = null;
|
||||||
|
|
||||||
|
if ($user->roles->pluck('name')->contains('senior-officer')) {
|
||||||
|
$userTeam = TeamsUsers::with('team')->firstWhere('user_id', $user->id);
|
||||||
|
$regionId = $userTeam?->team->regions_id;
|
||||||
|
$teamId = $userTeam?->teams_id;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
$teamsActivity = TeamsUsers::with(['user', 'team', 'team.regions', 'user.roles'])
|
||||||
|
->whereHas('team', function ($q) use ($regionId, $teamId) {
|
||||||
|
$q->when($regionId, fn ($q) => $q->where('regions_id', $regionId))
|
||||||
|
->when($teamId, fn ($q) => $q->where('id', $teamId));
|
||||||
|
})
|
||||||
|
->where('user_id', '!=', $user->id)
|
||||||
|
->whereHas('user.roles', fn ($q) => $q->whereIn('name', ['surveyor', 'surveyor-penilai']))
|
||||||
|
->get();
|
||||||
|
|
||||||
|
$teamId = is_array($teamId) ? $teamId : [$teamId];
|
||||||
|
|
||||||
|
$teamPenilai = Teams::with(['regions', 'teamsUsers', 'teamsUsers.user'])->whereNotIn(
|
||||||
|
'id',
|
||||||
|
$teamId
|
||||||
|
)->get();
|
||||||
|
|
||||||
|
return [
|
||||||
|
'teamsActivity' => $teamsActivity,
|
||||||
|
'teamPenilai' => $teamPenilai,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function showDetailsPermohonan($request,$id)
|
||||||
|
{
|
||||||
|
$query = Penilaian::with([
|
||||||
|
'permohonan',
|
||||||
|
'permohonan.debiture',
|
||||||
|
'permohonan.tujuanPenilaian',
|
||||||
|
'permohonan.debiture.documents.jenisJaminan',
|
||||||
|
'userPenilai' => function ($query) use ($id) {
|
||||||
|
$query->where('user_id', $id);
|
||||||
|
},
|
||||||
|
'permohonan.penilai',
|
||||||
|
'permohonan.approveEo',
|
||||||
|
'permohonan.approveDd',
|
||||||
|
'permohonan.approveSo',
|
||||||
|
|
||||||
|
])
|
||||||
|
->whereHas('userPenilai', function ($q) use ($id) {
|
||||||
|
$q->where('user_id', $id);
|
||||||
|
})
|
||||||
|
->whereHas('permohonan', function ($q) {
|
||||||
|
$q->whereIn('status', [
|
||||||
|
'assign',
|
||||||
|
'survey-completed',
|
||||||
|
'proses-laporan',
|
||||||
|
'paparan',
|
||||||
|
'proses-paparan',
|
||||||
|
'revisi-laporan',
|
||||||
|
'revisi-paparan',
|
||||||
|
'survey',
|
||||||
|
'proses-survey',
|
||||||
|
'request-reschedule',
|
||||||
|
'reschedule',
|
||||||
|
'rejected-reschedule',
|
||||||
|
'approved-reschedule',
|
||||||
|
'revisi-survey',
|
||||||
|
'revisi-pembayaran'
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Filter pencarian
|
||||||
|
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('status', 'LIKE', "%$search%");
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Sorting
|
||||||
|
if ($request->has('sortOrder') && !empty($request->get('sortOrder'))) {
|
||||||
|
$order = $request->get('sortOrder');
|
||||||
|
$column = $request->get('sortField');
|
||||||
|
$query->orderBy($column, $order);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hitung total records
|
||||||
|
$totalRecords = $query->count();
|
||||||
|
|
||||||
|
// Pagination
|
||||||
|
$size = $request->get('size', 10);
|
||||||
|
$page = $request->get('page', 1);
|
||||||
|
$offset = ($page - 1) * $size;
|
||||||
|
|
||||||
|
// Ambil data dengan pagination
|
||||||
|
$data = $query->skip($offset)->take($size)->get();
|
||||||
|
|
||||||
|
$data = $data->map(function ($item) {
|
||||||
|
$jeniAsset = null;
|
||||||
|
$statusPembayaran = trim(strtolower($item->permohonan->status_bayar ?? ''));
|
||||||
|
$tujuanPenilaian = $item->permohonan->tujuanPenilaian->name ?? null;
|
||||||
|
$plafond = $item->permohonan->nilaiPlafond->name ?? null;
|
||||||
|
|
||||||
|
$now = Carbon::now();
|
||||||
|
$type_report = $item->permohonan->penilai->type ?? "";
|
||||||
|
|
||||||
|
$hari = $hariPaparan = 0;
|
||||||
|
|
||||||
|
if ($type_report == "sederhana") {
|
||||||
|
$hari = 2;
|
||||||
|
$item->paparan = 'Tidak Ada';
|
||||||
|
} else {
|
||||||
|
if ($plafond == '< 2M') {
|
||||||
|
$item->paparan = 'Tidak Ada';
|
||||||
|
$hari = 3;
|
||||||
|
} elseif ($plafond == '2 M - 5 M') {
|
||||||
|
$hari = 3;
|
||||||
|
$hariPaparan = 2;
|
||||||
|
} else {
|
||||||
|
$hari = 5;
|
||||||
|
$hariPaparan = 3;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($tujuanPenilaian == 'RAP') {
|
||||||
|
$hari = 2;
|
||||||
|
$hariPaparan = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if ($item->permohonan && $item->permohonan->debiture) {
|
||||||
|
$jeniAsset = $item->permohonan->debiture->documents->first() ?? null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*$hariTambahan = 0;
|
||||||
|
|
||||||
|
if ($tujuanPenilaian == 'RAP') {
|
||||||
|
$hariTambahan = 2;
|
||||||
|
} else {
|
||||||
|
if ($statusPembayaran == 'sudah_bayar') {
|
||||||
|
$hariTambahan = 1; // H+1 untuk yang sudah bayar
|
||||||
|
} else {
|
||||||
|
$hariTambahan = 2; // H+2 untuk yang belum bayar
|
||||||
|
}
|
||||||
|
}*/
|
||||||
|
|
||||||
|
$tanggalMulai = $item->waktu_penilaian;
|
||||||
|
|
||||||
|
if ($tanggalMulai) {
|
||||||
|
if (!$tanggalMulai instanceof Carbon) {
|
||||||
|
$tanggalMulai = Carbon::parse($tanggalMulai);
|
||||||
|
}
|
||||||
|
$hariKerjaBerikutnya = hitungHariKerja($tanggalMulai->toDateString(), $tanggalMulai->copy()->addDays(1));
|
||||||
|
$hariKerjaBerikutnya = max($hariKerjaBerikutnya, 1);
|
||||||
|
$tanggalMulai = $tanggalMulai->copy()->addDays($hariKerjaBerikutnya);
|
||||||
|
|
||||||
|
// Konversi string tanggal ke objek Carbon jika belum
|
||||||
|
if (!$tanggalMulai instanceof Carbon) {
|
||||||
|
$tanggalMulai = Carbon::parse($tanggalMulai);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hitung tanggal selesai berdasarkan hari tambahan
|
||||||
|
$tanggalSelesai = $tanggalMulai->copy()->addDays($hari);
|
||||||
|
$tanggalPaparan = $tanggalMulai->copy()->addDays($hariPaparan);
|
||||||
|
|
||||||
|
// Hitung hari kerja
|
||||||
|
$hariKerja = hitungHariKerja($tanggalMulai->toDateString(), $tanggalSelesai->toDateString());
|
||||||
|
$hariKerja = max($hariKerja, $hari);
|
||||||
|
|
||||||
|
$hariKerjaPaparan = hitungHariKerja($tanggalMulai->toDateString(), $tanggalPaparan->toDateString());
|
||||||
|
$hariKerjaPaparan = max($hariKerjaPaparan, $hariPaparan);
|
||||||
|
|
||||||
|
// Set due date SLA
|
||||||
|
$dueDateSla = $tanggalMulai->copy()->addDays($hariKerja);
|
||||||
|
$dueDateSlaPaparan = $tanggalMulai->copy()->addDays($hariKerjaPaparan);
|
||||||
|
|
||||||
|
// Cek apakah sudah melewati due date
|
||||||
|
/*if ($now->greaterThan($dueDateSla)) {
|
||||||
|
$item->due_date_sla = null;
|
||||||
|
} else {
|
||||||
|
$item->due_date_sla = $dueDateSla->toDateString();
|
||||||
|
}*/
|
||||||
|
|
||||||
|
$item->due_date_sla = $dueDateSla->toDateString();
|
||||||
|
$item->paparan = $dueDateSlaPaparan->toDateString();
|
||||||
|
} else {
|
||||||
|
$item->due_date_sla = null;
|
||||||
|
$item->paparan = null;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return $item;
|
||||||
|
});
|
||||||
|
|
||||||
|
$filteredRecords = $data->count();
|
||||||
|
$pageCount = ceil($totalRecords / $size);
|
||||||
|
|
||||||
|
// Return data dalam bentuk JSON
|
||||||
|
return response()->json([
|
||||||
|
'draw' => $request->get('draw'),
|
||||||
|
'recordsTotal' => $totalRecords,
|
||||||
|
'recordsFiltered' => $filteredRecords,
|
||||||
|
'pageCount' => $pageCount,
|
||||||
|
'page' => $page,
|
||||||
|
'totalCount' => $totalRecords,
|
||||||
|
'data' => $data
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
128
app/Services/LaporanSLAPenilaiService.php
Normal file
128
app/Services/LaporanSLAPenilaiService.php
Normal file
@@ -0,0 +1,128 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Services;
|
||||||
|
|
||||||
|
use Modules\Lpj\Models\Permohonan;
|
||||||
|
use Modules\Lpj\Models\Penilaian;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
|
||||||
|
class LaporanSLAPenilaiService
|
||||||
|
{
|
||||||
|
public function dataForDatatables(Request $request)
|
||||||
|
{
|
||||||
|
// Retrieve data from the database
|
||||||
|
$query = Permohonan::query();
|
||||||
|
$query = $query->where('status', 'done');
|
||||||
|
|
||||||
|
// Apply search filter if provided
|
||||||
|
if ($request->has('search') && !empty($request->get('search'))) {
|
||||||
|
$search = json_decode($request->get('search'));
|
||||||
|
|
||||||
|
if (isset($search->start_date) || isset($search->end_date)) {
|
||||||
|
$query->whereBetween('tanggal_permohonan', [
|
||||||
|
$search->start_date ?? '1900-01-01',
|
||||||
|
$search->end_date ?? now()->toDateString()
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (isset($search->penilai_id) && !empty($search->penilai_id)) {
|
||||||
|
$query->whereHas('penilaian._user_penilai.userPenilaiTeam', function($q) use ($search) {
|
||||||
|
$q->where('user_id', $search->penilai_id);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($search->search)) {
|
||||||
|
|
||||||
|
$query->where(function ($q) use ($search) {
|
||||||
|
$q->where('nomor_registrasi', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhere('tanggal_permohonan', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('user', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('tujuanPenilaian', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('branch', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('jenisFasilitasKredit', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('jenisPenilaian', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhere('status', 'LIKE', '%' . $search->search . '%');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Apply sorting if provided
|
||||||
|
if ($request->has('sortOrder') && !empty($request->get('sortOrder'))) {
|
||||||
|
$order = $request->get('sortOrder');
|
||||||
|
$column = $request->get('sortField');
|
||||||
|
$query->orderBy($column, $order);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the total count of records
|
||||||
|
$totalRecords = $query->count();
|
||||||
|
|
||||||
|
// Apply pagination if provided
|
||||||
|
if ($request->has('page') && $request->has('size')) {
|
||||||
|
$page = $request->get('page');
|
||||||
|
$size = $request->get('size');
|
||||||
|
$offset = ($page - 1) * $size; // Calculate the offset
|
||||||
|
|
||||||
|
$query->skip($offset)->take($size);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the filtered count of records
|
||||||
|
$filteredRecords = $query->count();
|
||||||
|
|
||||||
|
// Get the data for the current page
|
||||||
|
$data = $query->with(['debiture.branch'])->get();
|
||||||
|
|
||||||
|
$data = $data->map(function ($permohonan) {
|
||||||
|
$luas_tanah = 0;
|
||||||
|
$luas_bangunan = 0;
|
||||||
|
$nilai_tanah = 0;
|
||||||
|
$nilai_bangunan = 0;
|
||||||
|
$npw = 0;
|
||||||
|
$nilai_liquidasi = 0;
|
||||||
|
if (isset($permohonan->penilai->lpj)) {
|
||||||
|
$lpj = json_decode($permohonan->penilai->lpj, true);
|
||||||
|
$npw = str_replace('.', '', $lpj['total_nilai_pasar_wajar'] ?? 0);
|
||||||
|
|
||||||
|
$luas_tanah = $lpj['luas_tanah'] ?? 0;
|
||||||
|
$luas_bangunan = $lpj['luas_bangunan'] ?? 0;
|
||||||
|
// Calculate nilai_tanah dynamically by looking for all keys that start with 'nilai_tanah_'
|
||||||
|
$nilai_tanah = str_replace('.', '', $lpj['nilai_tanah_2'] ?? 0);
|
||||||
|
|
||||||
|
$nilai_bangunan = str_replace('.', '', $lpj['nilai_bangunan_2'] ?? 0);
|
||||||
|
$nilai_liquidasi = str_replace('.', '', $lpj['likuidasi_nilai_2'] ?? 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
'id' => $permohonan->id,
|
||||||
|
'nomor_registrasi' => $permohonan->nomor_registrasi,
|
||||||
|
'tanggal_permohonan' => $permohonan->tanggal_permohonan,
|
||||||
|
'branch' => $permohonan->debiture?->branch?->name,
|
||||||
|
'name' => $permohonan->debiture?->name,
|
||||||
|
'pemohon' => $permohonan->creator?->name,
|
||||||
|
'tujuan_penilaian' => $permohonan->tujuanPenilaian?->name,
|
||||||
|
'jenis_agunan' => $permohonan->documents?->pluck('jenisJaminan.name')->unique()->implode(', '),
|
||||||
|
|
||||||
|
'tanggal_laporan' => $permohonan->approval_dd_at ?? $permohonan->approval_eo_at ?? '',
|
||||||
|
'tanggal_review' => $permohonan->penilaian?->tanggal_kunjungan ?? '',
|
||||||
|
'nama_penilai' => $permohonan->penilaian?->_user_penilai?->userPenilaiTeam?->name,
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
// Calculate the page count
|
||||||
|
$pageCount = ceil($totalRecords / $request->get('size'));
|
||||||
|
|
||||||
|
// Calculate the current page number
|
||||||
|
$currentPage = $request->get('page', 1);
|
||||||
|
|
||||||
|
// Return the response data as a JSON object
|
||||||
|
return response()->json([
|
||||||
|
'draw' => $request->get('draw'),
|
||||||
|
'recordsTotal' => $totalRecords,
|
||||||
|
'recordsFiltered' => $filteredRecords,
|
||||||
|
'pageCount' => $pageCount,
|
||||||
|
'page' => $currentPage,
|
||||||
|
'totalCount' => $totalRecords,
|
||||||
|
'data' => $data,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
198
app/Services/LaporanUserService.php
Normal file
198
app/Services/LaporanUserService.php
Normal file
@@ -0,0 +1,198 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Services;
|
||||||
|
use Modules\Lpj\Models\Permohonan;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
|
||||||
|
class LaporanUserService
|
||||||
|
{
|
||||||
|
public function getUserPemohon($search = null)
|
||||||
|
{
|
||||||
|
return Permohonan::join('users', 'users.id', '=', 'permohonan.user_id')
|
||||||
|
->whereNotNull('permohonan.nomor_registrasi')
|
||||||
|
->when($search, function ($query) use ($search) {
|
||||||
|
$query->where('users.name', 'like', "%$search%");
|
||||||
|
})
|
||||||
|
->select('users.id', 'users.name')
|
||||||
|
->distinct()
|
||||||
|
->orderBy('users.name')
|
||||||
|
->limit(20)
|
||||||
|
->get();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function dataForDatatables(Request $request)
|
||||||
|
{
|
||||||
|
|
||||||
|
// Retrieve data from the database
|
||||||
|
$query = Permohonan::query();
|
||||||
|
$query = $query->where('status', 'done');
|
||||||
|
|
||||||
|
// Apply search filter if provided
|
||||||
|
if ($request->has('search') && !empty($request->get('search'))) {
|
||||||
|
$search = json_decode($request->get('search'));
|
||||||
|
|
||||||
|
if (isset($search->start_date) || isset($search->end_date)) {
|
||||||
|
$query->whereBetween('tanggal_permohonan', [
|
||||||
|
$search->start_date ?? '1900-01-01',
|
||||||
|
$search->end_date ?? now()->toDateString()
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Filter by branch if provided
|
||||||
|
if (isset($search->user_id) && !empty($search->user_id)) {
|
||||||
|
$query->where('user_id', $search->user_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($search->search)) {
|
||||||
|
|
||||||
|
$query->where(function ($q) use ($search) {
|
||||||
|
$q->where('nomor_registrasi', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhere('tanggal_permohonan', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('user', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('tujuanPenilaian', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('branch', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('jenisFasilitasKredit', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhereRelation('jenisPenilaian', 'name', 'LIKE', '%' . $search->search . '%');
|
||||||
|
$q->orWhere('status', 'LIKE', '%' . $search->search . '%');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Apply sorting if provided
|
||||||
|
if ($request->has('sortOrder') && !empty($request->get('sortOrder'))) {
|
||||||
|
$order = $request->get('sortOrder');
|
||||||
|
$column = $request->get('sortField');
|
||||||
|
$query->orderBy($column, $order);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the total count of records
|
||||||
|
$totalRecords = $query->count();
|
||||||
|
|
||||||
|
// Apply pagination if provided
|
||||||
|
if ($request->has('page') && $request->has('size')) {
|
||||||
|
$page = $request->get('page');
|
||||||
|
$size = $request->get('size');
|
||||||
|
$offset = ($page - 1) * $size; // Calculate the offset
|
||||||
|
|
||||||
|
$query->skip($offset)->take($size);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the filtered count of records
|
||||||
|
$filteredRecords = $query->count();
|
||||||
|
|
||||||
|
// Get the data for the current page
|
||||||
|
$data = $query->with(['debiture.branch'])->get();
|
||||||
|
|
||||||
|
$data = $data->map(function ($permohonan) {
|
||||||
|
$luas_tanah = 0;
|
||||||
|
$luas_bangunan = 0;
|
||||||
|
$nilai_tanah = 0;
|
||||||
|
$nilai_bangunan = 0;
|
||||||
|
$npw = 0;
|
||||||
|
$nilai_liquidasi = 0;
|
||||||
|
|
||||||
|
if (isset($permohonan->penilai->lpj)) {
|
||||||
|
$lpj = json_decode($permohonan->penilai->lpj, true);
|
||||||
|
$npw = str_replace('.', '', $lpj['total_nilai_pasar_wajar'] ?? 0);
|
||||||
|
|
||||||
|
$luas_tanah = $lpj['luas_tanah'] ?? 0;
|
||||||
|
$luas_bangunan = $lpj['luas_bangunan'] ?? 0;
|
||||||
|
// Calculate nilai_tanah dynamically by looking for all keys that start with 'nilai_tanah_'
|
||||||
|
$nilai_tanah = str_replace('.', '', $lpj['nilai_tanah_2'] ?? 0);
|
||||||
|
|
||||||
|
$nilai_bangunan = str_replace('.', '', $lpj['nilai_bangunan_2'] ?? 0);
|
||||||
|
$nilai_liquidasi = str_replace('.', '', $lpj['likuidasi_nilai_2'] ?? 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
'id' => $permohonan->id,
|
||||||
|
'nomor_registrasi' => $permohonan->nomor_registrasi,
|
||||||
|
'jenis_penilaian' => $permohonan->jenisPenilaian?->name,
|
||||||
|
'tujuan_penilaian' => $permohonan->tujuanPenilaian?->name,
|
||||||
|
'jenis_fasilitas_kredit' => $permohonan->jenisFasilitasKredit?->name,
|
||||||
|
'branch' => $permohonan->debiture->branch?->name,
|
||||||
|
'pemohon' => $permohonan->creator?->name,
|
||||||
|
'cif' => $permohonan->debiture->cif,
|
||||||
|
'name' => $permohonan->debiture?->name,
|
||||||
|
'jenis_agunan' => $permohonan->documents?->pluck('jenisJaminan.name')
|
||||||
|
->unique()
|
||||||
|
->implode(', '),
|
||||||
|
'alamat_agunan' => $permohonan->documents?->map(function ($document) {
|
||||||
|
return formatAlamat($document);
|
||||||
|
})->unique()->implode(', '),
|
||||||
|
'bukti_kepemilikan' => (function () use ($permohonan) {
|
||||||
|
$legalitasItems = $permohonan->documents?->flatMap(function ($document) {
|
||||||
|
return $document->detail->map(function ($detail) {
|
||||||
|
// Jika tidak ada jenis legalitas jaminan, lewati
|
||||||
|
if (empty($detail->jenisLegalitasJaminan)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hanya tampilkan detail yang memiliki dokumen_jaminan
|
||||||
|
if (empty($detail->dokumen_jaminan)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Tampilkan nama legalitas jaminan saja
|
||||||
|
return $detail->jenisLegalitasJaminan->name ?? '';
|
||||||
|
});
|
||||||
|
})->filter()->unique()->values()->toArray();
|
||||||
|
|
||||||
|
// Buat daftar bernomor
|
||||||
|
$result = '';
|
||||||
|
foreach ($legalitasItems as $index => $item) {
|
||||||
|
$result .= ($index + 1) . '. ' . $item . "\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
return $result;
|
||||||
|
})(),
|
||||||
|
'nama_pemilik' => $permohonan->documents?->pluck('pemilik.name')
|
||||||
|
->unique()
|
||||||
|
->implode(', '),
|
||||||
|
'luas_tanah' => $luas_tanah . ' m²',
|
||||||
|
'nilai_tanah' => formatRupiah($nilai_tanah, 2),
|
||||||
|
'luas_bangunan' => $luas_bangunan . ' m²',
|
||||||
|
'nilai_bangunan' => formatRupiah($nilai_bangunan, 2),
|
||||||
|
'nilai_njop' => formatRupiah($permohonan->nilai_njop, 2),
|
||||||
|
'nilai_pasar_wajar' => formatRupiah($npw, 2),
|
||||||
|
'nilai_likuidasi' => formatRupiah($nilai_liquidasi, 2),
|
||||||
|
'tanggal_documen_diterima' => $permohonan->documents?->map(function ($document) {
|
||||||
|
return $document->created_at->format('d-m-Y');
|
||||||
|
}),
|
||||||
|
'tanggal_spk' => '',
|
||||||
|
'nomor_spk' => '',
|
||||||
|
'tanggal_rencana_kunjunagn' => '',
|
||||||
|
'tanggal_kunjungan' => '',
|
||||||
|
'taggal_delivered' => '',
|
||||||
|
'jangka_waktu_sla' => '',
|
||||||
|
'nama_penilai' => $permohonan->penilaian?->_user_penilai?->userPenilaiTeam?->name,
|
||||||
|
'nama_team_leader' => $permohonan->penilaian?->teams,
|
||||||
|
'saran' => '',
|
||||||
|
'catatan' => '',
|
||||||
|
|
||||||
|
|
||||||
|
'tanggal_permohonan' => $permohonan->tanggal_permohonan,
|
||||||
|
'tanggal_laporan' => $permohonan->approval_dd_at ?? $permohonan->approval_eo_at ?? '',
|
||||||
|
'tanggal_review' => $permohonan->penilaian?->tanggal_kunjungan ?? '',
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
// Calculate the page count
|
||||||
|
$pageCount = ceil($totalRecords / $request->get('size'));
|
||||||
|
|
||||||
|
// Calculate the current page number
|
||||||
|
$currentPage = $request->get('page') ?: 1;
|
||||||
|
|
||||||
|
// Return the response data as a JSON object
|
||||||
|
return response()->json([
|
||||||
|
'draw' => $request->get('draw'),
|
||||||
|
'recordsTotal' => $totalRecords,
|
||||||
|
'recordsFiltered' => $filteredRecords,
|
||||||
|
'pageCount' => $pageCount,
|
||||||
|
'page' => $currentPage,
|
||||||
|
'totalCount' => $totalRecords,
|
||||||
|
'data' => $data,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
63
app/Services/RekapHarianService.php
Normal file
63
app/Services/RekapHarianService.php
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Services;
|
||||||
|
|
||||||
|
class RekapHarianService
|
||||||
|
{
|
||||||
|
public function getRekapHarian()
|
||||||
|
{
|
||||||
|
// return $id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function totalLaporan()
|
||||||
|
{
|
||||||
|
$jenis_penilaian = JenisPenilaian::all();
|
||||||
|
$laporan = [];
|
||||||
|
$grandTotal = [];
|
||||||
|
|
||||||
|
foreach ($jenis_penilaian as $index => $jenis) {
|
||||||
|
|
||||||
|
$totalLaporanDebiture = $this->totalLaporanDebiture();
|
||||||
|
$totalKunjunganDebiture = $this->totalKunjunganDebiture();
|
||||||
|
$totalKunjunganLokasi = $this->totalKunjunganLokasi();
|
||||||
|
|
||||||
|
|
||||||
|
$grandTotal = [
|
||||||
|
'laporan_debiture' => 0,
|
||||||
|
'debiture' => 0,
|
||||||
|
'lokasi' => 0,
|
||||||
|
'pipeline' => 0
|
||||||
|
];
|
||||||
|
}
|
||||||
|
return $grandTotal;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private function totalLaporanDebiture()
|
||||||
|
{
|
||||||
|
$query = [
|
||||||
|
'jenis_penilaian_id' => 1,
|
||||||
|
'total' => 2
|
||||||
|
];
|
||||||
|
return $query;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function totalKunjunganDebiture()
|
||||||
|
{
|
||||||
|
$query = [
|
||||||
|
'jenis_penilaian_id' => 1,
|
||||||
|
'total' => 2
|
||||||
|
];
|
||||||
|
return $query;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function totalKunjunganLokasi()
|
||||||
|
{
|
||||||
|
$query = [
|
||||||
|
'jenis_penilaian_id' => 1,
|
||||||
|
'total' => 2
|
||||||
|
];
|
||||||
|
return $query;
|
||||||
|
}
|
||||||
|
}
|
||||||
116
module.json
116
module.json
@@ -115,6 +115,122 @@
|
|||||||
"EO Appraisal",
|
"EO Appraisal",
|
||||||
"senior-officer"
|
"senior-officer"
|
||||||
]
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": "Rekap Harian So",
|
||||||
|
"path": "rekap-harian-so",
|
||||||
|
"icon": "ki-filled ki-filter-tablet text-lg text-primary",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": [
|
||||||
|
"administrator",
|
||||||
|
"senior-officer"
|
||||||
|
]
|
||||||
|
}, {
|
||||||
|
"title": "Laporan Biaya Lpj",
|
||||||
|
"path": "laporan-biaya",
|
||||||
|
"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"
|
||||||
|
],
|
||||||
|
"sub": [
|
||||||
|
{
|
||||||
|
"title": "Intenal",
|
||||||
|
"path": "laporan-biaya.internal",
|
||||||
|
"icon": "ki-filled ki-two-credit-cart text-lg text-primary",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": [
|
||||||
|
"administrator",
|
||||||
|
"pemohon-ao",
|
||||||
|
"pemohon-eo",
|
||||||
|
"admin",
|
||||||
|
"DD Appraisal",
|
||||||
|
"EO Appraisal",
|
||||||
|
"senior-officer"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": "External",
|
||||||
|
"path": "laporan-biaya.external",
|
||||||
|
"icon": "ki-filled ki-two-credit-cart text-lg text-primary",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": [
|
||||||
|
"administrator",
|
||||||
|
"pemohon-ao",
|
||||||
|
"pemohon-eo",
|
||||||
|
"admin",
|
||||||
|
"DD Appraisal",
|
||||||
|
"EO Appraisal",
|
||||||
|
"senior-officer"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},{
|
||||||
|
"title": "Laporan Debitur",
|
||||||
|
"path": "laporan-debiture",
|
||||||
|
"icon": "ki-filled ki-filter-tablet text-lg text-primary",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": [
|
||||||
|
"administrator",
|
||||||
|
"senior-officer"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": "Laporan User",
|
||||||
|
"path": "laporan-user",
|
||||||
|
"icon": "ki-filled ki-filter-tablet text-lg text-primary",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": [
|
||||||
|
"administrator",
|
||||||
|
"senior-officer"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": "Laporan Monitoring so",
|
||||||
|
"path": "laporan-monitoring",
|
||||||
|
"icon": "ki-filled ki-filter-tablet text-lg text-primary",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": [
|
||||||
|
"administrator",
|
||||||
|
"senior-officer"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": "Laporan SLA Penilai",
|
||||||
|
"path": "laporan-sla-penilai",
|
||||||
|
"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"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"otorisator": [
|
"otorisator": [
|
||||||
|
|||||||
293
resources/views/dashboard/index.blade.php
Normal file
293
resources/views/dashboard/index.blade.php
Normal file
@@ -0,0 +1,293 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<div class="w-full grid gap-6 mx-auto">
|
||||||
|
<!-- Header Section -->
|
||||||
|
<div class="flex flex-wrap items-center lg:items-end justify-between gap-5 pb-8">
|
||||||
|
<div class="flex flex-col justify-center gap-3">
|
||||||
|
<h1 class="text-2xl font-bold leading-none text-gray-800">
|
||||||
|
Dashboard
|
||||||
|
</h1>
|
||||||
|
<div class="flex items-center gap-2 text-sm font-medium text-gray-600">
|
||||||
|
<i class="ki-filled ki-clipboard"></i>
|
||||||
|
Selamat datang, <span class="text-primary font-semibold">{{ auth()->user()->name }}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center gap-3 w-[30%]">
|
||||||
|
<div class="flex items-center gap-2 w-full">
|
||||||
|
<input type="date" class="input" name="start_date" id="start_date">
|
||||||
|
<input type="date" class="input" name="end_date" id="end_date">
|
||||||
|
</div>
|
||||||
|
<button class="btn btn-primary" id="filter" type="button" onclick="filterDashboard()">
|
||||||
|
<i class="ki-outline ki-filter fs-2 me-1"></i>
|
||||||
|
Filter</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Stats Cards -->
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 gap-6">
|
||||||
|
|
||||||
|
@foreach ($dashboard['count_resume'] as $status => $count)
|
||||||
|
@php
|
||||||
|
|
||||||
|
$gradientFrom = $status === 'batal' ? 'from-red-50' : 'from-amber-50';
|
||||||
|
$gradientTo = $status === 'batal' ? 'to-red-100' : 'to-amber-100';
|
||||||
|
$borderColor = $status === 'batal' ? 'border-red-200' : 'border-amber-200';
|
||||||
|
$iconBg = $status === 'batal' ? 'bg-red-500' : 'bg-amber-500';
|
||||||
|
$iconColor = $status === 'batal' ? 'text-red-500' : 'text-amber-500';
|
||||||
|
$textColor = $status === 'batal' ? 'text-red-800' : 'text-amber-800';
|
||||||
|
$cardTitle = $status === 'batal' ? 'Batal dari Cabang' : 'Menunggu Keputusan Cabang';
|
||||||
|
@endphp
|
||||||
|
|
||||||
|
<div class="card bg-gradient-to-br {{ $gradientFrom }} {{ $gradientTo }} {{ $borderColor }}">
|
||||||
|
<div class="card-header border-b {{ $borderColor }}">
|
||||||
|
<div class="flex items-center gap-3">
|
||||||
|
<div class="w-10 h-10 {{ $iconBg }} rounded-lg flex items-center justify-center">
|
||||||
|
<i
|
||||||
|
class="ki-filled {{ $status === 'batal' ? 'ki-cross-circle text-white' : 'ki-time text-white' }}"></i>
|
||||||
|
</div>
|
||||||
|
<h3 class="card-title {{ $textColor }} font-semibold">{{ $cardTitle }}</h3>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 gap-4">
|
||||||
|
<div
|
||||||
|
class="bg-white rounded-xl p-4 shadow-sm border {{ $borderColor }} hover:shadow-md transition-shadow">
|
||||||
|
<div class="flex items-center justify-between">
|
||||||
|
<div>
|
||||||
|
<h4 class="text-sm font-semibold text-gray-700 mb-1">Jabodetabek</h4>
|
||||||
|
<span
|
||||||
|
class="text-2xl font-bold {{ $status === 'batal' ? 'text-red-600' : 'text-amber-600' }}">
|
||||||
|
{{ $count['jabodetabek']['count_report'] ?? 0 }}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<div class="w-8 h-8 {{ $gradientFrom }} rounded-full flex items-center justify-center">
|
||||||
|
<i class="ki-filled {{ $iconColor }}"></i>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div
|
||||||
|
class="bg-white rounded-xl p-4 shadow-sm border {{ $borderColor }} hover:shadow-md transition-shadow">
|
||||||
|
<div class="flex items-center justify-between">
|
||||||
|
<div>
|
||||||
|
<h4 class="text-sm font-semibold text-gray-700 mb-1">Luar Jabodetabek</h4>
|
||||||
|
<span
|
||||||
|
class="text-2xl font-bold {{ $status === 'batal' ? 'text-red-600' : 'text-amber-600' }}">
|
||||||
|
{{ $count['non-jabodetabek']['count_report'] ?? 0 }}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<div class="w-8 h-8 {{ $gradientFrom }} rounded-full flex items-center justify-center">
|
||||||
|
<i class="ki-filled {{ $iconColor }}"></i>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@endforeach
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<!-- Chart Section -->
|
||||||
|
<div class="card ">
|
||||||
|
<div class="card-header border-b border-blue-200">
|
||||||
|
<div class="flex items-center justify-between">
|
||||||
|
<div class="flex items-center gap-3">
|
||||||
|
<div class="w-10 h-10 bg-blue-500 rounded-lg flex items-center justify-center">
|
||||||
|
<i class="ki-filled ki-chart-simple-2 text-white"></i>
|
||||||
|
</div>
|
||||||
|
<h3 class="text-lg font-semibold text-blue-800">Pendapatan Appraisal</h3>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="bg-white rounded-xl p-4 shadow-sm">
|
||||||
|
<table class="table table-auto w-full">
|
||||||
|
<thead class="bg-gray-50">
|
||||||
|
<tr>
|
||||||
|
<th
|
||||||
|
class="px-4 py-3 text-left text-xs font-semibold text-gray-700 uppercase tracking-wider border-r border-gray-200">
|
||||||
|
Bulan
|
||||||
|
</th>
|
||||||
|
<th
|
||||||
|
class="px-4 py-3 text-center text-xs font-semibold text-gray-700 uppercase tracking-wider border-r border-gray-200">
|
||||||
|
Jumlah
|
||||||
|
</th>
|
||||||
|
<th
|
||||||
|
class="px-4 py-3 text-center text-xs font-semibold text-gray-700 uppercase tracking-wider">
|
||||||
|
Akumulasi
|
||||||
|
</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody class="bg-white divide-y divide-gray-200">
|
||||||
|
@foreach ($dashboard['count_pendapatan'] as $month => $data)
|
||||||
|
<tr class="hover:bg-gray-50 transition-colors">
|
||||||
|
<!-- Kolom Nama month -->
|
||||||
|
<td class="px-4 py-3 text-sm font-medium text-gray-900 border-r border-gray-200">
|
||||||
|
{{ ucfirst($month) }}
|
||||||
|
</td>
|
||||||
|
|
||||||
|
<!-- Kolom Total Laporan -->
|
||||||
|
<td class="px-4 py-3 text-sm text-gray-700 text-center border-r border-gray-200">
|
||||||
|
{{ $data['total_jumlah'] ?? '-' }}
|
||||||
|
</td>
|
||||||
|
|
||||||
|
<!-- Kolom Total Debitur -->
|
||||||
|
<td class="px-4 py-3 text-sm text-gray-700 text-center border-r border-gray-200">
|
||||||
|
{{ $data['total_akumulasi'] ?? '-' }}
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
@endforeach
|
||||||
|
<!-- Add more rows as needed -->
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Tables Section -->
|
||||||
|
<div class="flex w-full gap-6">
|
||||||
|
<!-- Laporan Internal -->
|
||||||
|
<div class="card w-[60%] ">
|
||||||
|
<div class="card-header border-b border-green-200">
|
||||||
|
<div class="flex items-center gap-3">
|
||||||
|
<div class="w-10 h-10 bg-green-500 rounded-lg flex items-center justify-center">
|
||||||
|
<i class="ki-filled ki-document text-white"></i>
|
||||||
|
</div>
|
||||||
|
<h3 class="text-lg font-semibold text-green-800">Laporan Internal</h3>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="bg-white rounded-xl overflow-hidden shadow-sm">
|
||||||
|
<table class="table table-auto w-full">
|
||||||
|
<thead class="bg-gray-50">
|
||||||
|
<tr>
|
||||||
|
<th rowspan="2"
|
||||||
|
class="px-4 py-3 text-left text-xs font-semibold text-gray-700 uppercase tracking-wider border-r border-gray-200">
|
||||||
|
Bulan
|
||||||
|
</th>
|
||||||
|
<th colspan="2"
|
||||||
|
class="px-4 py-3 text-center text-xs font-semibold text-gray-700 uppercase tracking-wider border-r border-gray-200">
|
||||||
|
Jabodetabek
|
||||||
|
</th>
|
||||||
|
<th colspan="2"
|
||||||
|
class="px-4 py-3 text-center text-xs font-semibold text-gray-700 uppercase tracking-wider">
|
||||||
|
Luar Jabodetabek
|
||||||
|
</th>
|
||||||
|
</tr>
|
||||||
|
<tr class="border-t border-gray-200">
|
||||||
|
<th
|
||||||
|
class="px-4 py-3 text-center text-xs font-semibold text-gray-700 uppercase tracking-wider border-r border-gray-200">
|
||||||
|
Laporan
|
||||||
|
</th>
|
||||||
|
<th
|
||||||
|
class="px-4 py-3 text-center text-xs font-semibold text-gray-700 uppercase tracking-wider border-r border-gray-200">
|
||||||
|
Debitur
|
||||||
|
</th>
|
||||||
|
<th
|
||||||
|
class="px-4 py-3 text-center text-xs font-semibold text-gray-700 uppercase tracking-wider border-r border-gray-200">
|
||||||
|
Laporan
|
||||||
|
</th>
|
||||||
|
<th
|
||||||
|
class="px-4 py-3 text-center text-xs font-semibold text-gray-700 uppercase tracking-wider">
|
||||||
|
Debitur
|
||||||
|
</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody class="bg-white divide-y divide-gray-200">
|
||||||
|
@foreach ($dashboard['count_lpj_internal'] as $month => $regions)
|
||||||
|
<tr class="hover:bg-gray-50 transition-colors">
|
||||||
|
<td class="px-4 py-2 text-sm font-medium text-gray-900">
|
||||||
|
{{ ucfirst($month) }}
|
||||||
|
</td>
|
||||||
|
<td class="px-4 py-2 text-sm text-center text-gray-700">
|
||||||
|
{{ $regions['jabodetabek']['total_laporan'] ?? '-' }}
|
||||||
|
</td>
|
||||||
|
<td class="px-4 py-2 text-sm text-center text-gray-700">
|
||||||
|
{{ $regions['jabodetabek']['total_debiture'] ?? '-' }}
|
||||||
|
</td>
|
||||||
|
<td class="px-4 py-2 text-sm text-center text-gray-700">
|
||||||
|
{{ $regions['non-jabodetabek']['total_laporan'] ?? '-' }}
|
||||||
|
</td>
|
||||||
|
<td class="px-4 py-2 text-sm text-center text-gray-700">
|
||||||
|
{{ $regions['non-jabodetabek']['total_debiture'] ?? '-' }}
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
@endforeach
|
||||||
|
<!-- Add more rows as needed -->
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Laporan Eksternal -->
|
||||||
|
<div class="card w-[40%]">
|
||||||
|
<div class="card-header border-b border-purple-200">
|
||||||
|
<div class="flex items-center gap-3">
|
||||||
|
<div class="w-10 h-10 bg-purple-500 rounded-lg flex items-center justify-center">
|
||||||
|
<i class="ki-filled ki-tab-tablet text-white"></i>
|
||||||
|
</div>
|
||||||
|
<h3 class="text-lg font-semibold text-purple-800">Laporan Eksternal</h3>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="bg-white rounded-xl overflow-hidden shadow-sm">
|
||||||
|
<table class="table table-auto w-full">
|
||||||
|
<thead class="bg-gray-50">
|
||||||
|
<tr>
|
||||||
|
<th
|
||||||
|
class="px-4 py-3 text-left text-xs font-semibold text-gray-700 uppercase tracking-wider border-r border-gray-200">
|
||||||
|
Bulan
|
||||||
|
</th>
|
||||||
|
<th
|
||||||
|
class="px-4 py-3 text-center text-xs font-semibold text-gray-700 uppercase tracking-wider border-r border-gray-200">
|
||||||
|
Laporan
|
||||||
|
</th>
|
||||||
|
<th
|
||||||
|
class="px-4 py-3 text-center text-xs font-semibold text-gray-700 uppercase tracking-wider">
|
||||||
|
Debitur
|
||||||
|
</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody class="bg-white divide-y divide-gray-200">
|
||||||
|
@foreach ($dashboard['count_lpj_eksternal'] as $month => $data)
|
||||||
|
<tr class="hover:bg-gray-50 transition-colors">
|
||||||
|
<!-- Kolom Nama month -->
|
||||||
|
<td class="px-4 py-3 text-sm font-medium text-gray-900 border-r border-gray-200">
|
||||||
|
{{ ucfirst($month) }}
|
||||||
|
</td>
|
||||||
|
|
||||||
|
<!-- Kolom Total Laporan -->
|
||||||
|
<td class="px-4 py-3 text-sm text-gray-700 text-center border-r border-gray-200">
|
||||||
|
{{ $data['total_laporan'] ?? '-' }}
|
||||||
|
</td>
|
||||||
|
|
||||||
|
<!-- Kolom Total Debitur -->
|
||||||
|
<td class="px-4 py-3 text-sm text-gray-700 text-center border-r border-gray-200">
|
||||||
|
{{ $data['total_debiture'] ?? '-' }}
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
@endforeach
|
||||||
|
<!-- Add more rows as needed -->
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Chart.js CDN -->
|
||||||
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/3.9.1/chart.min.js"></script>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
function filterDashboard() {
|
||||||
|
const start_date = document.getElementById('start_date').value;
|
||||||
|
const end_date = document.getElementById('end_date').value;
|
||||||
|
window.location.href = `?start_date=${start_date}&end_date=${end_date}`;
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
<!-- Chart initialization script -->
|
||||||
|
|
||||||
|
@endsection
|
||||||
499
resources/views/laporan-biaya/external.blade.php
Normal file
499
resources/views/laporan-biaya/external.blade.php
Normal file
@@ -0,0 +1,499 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render('laporan-hasil-penilaian-jaminan-internal-external') }}
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||||
|
<!-- Filter Card -->
|
||||||
|
<div class="card border border-agi-100">
|
||||||
|
<div class="card-header bg-agi-50 py-5">
|
||||||
|
<h3 class="card-title">Filter Laporan</h3>
|
||||||
|
</div>
|
||||||
|
<div class="card-body grid gap-4">
|
||||||
|
<!-- Search field at the top, full width -->
|
||||||
|
<div class="flex flex-col w-full">
|
||||||
|
<label class="text-sm font-medium mb-1">Pencarian</label>
|
||||||
|
<label class="input input-sm">
|
||||||
|
<i class="ki-filled ki-magnifier"></i>
|
||||||
|
<input placeholder="Search Laporan Hasil Penilaian Jaminan Internal & External" id="search" type="text" value="">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Other filter fields in grid layout -->
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4">
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Tanggal Awal</label>
|
||||||
|
<label class="input">
|
||||||
|
<input placeholder="Tanggal Awal" id="start_date" type="date">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Tanggal Akhir</label>
|
||||||
|
<label class="input">
|
||||||
|
<input placeholder="Tanggal Akhir" id="end_date" type="date">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Cabang</label>
|
||||||
|
<select class="select tomselect" id="branch_filter">
|
||||||
|
<option value="">Semua Cabang</option>
|
||||||
|
@foreach(\Modules\Basicdata\Models\Branch::where('status', 1)->get() as $branch)
|
||||||
|
<option value="{{ $branch->id }}">{{ $branch->name }}</option>
|
||||||
|
@endforeach
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Penilai</label>
|
||||||
|
<select class="select tomselect" id="penilai_filter">
|
||||||
|
<option value="">Semua Penilai</option>
|
||||||
|
@foreach(\MOdules\Usermanagement\Models\User::role(['penilai','surveyor'])->get() as $penilai)
|
||||||
|
<option value="{{ $penilai->id }}">{{ $penilai->name }}</option>
|
||||||
|
@endforeach
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Buttons row at the bottom -->
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 gap-4 mt-2">
|
||||||
|
<button class="btn btn-sm btn-primary" id="filter_tanggal">
|
||||||
|
<i class="ki-outline ki-filter fs-2 me-1"></i>
|
||||||
|
Terapkan Filter
|
||||||
|
</button>
|
||||||
|
<a class="btn btn-sm btn-light" href="{{ route('laporan-hasil-penilaian-jaminan-internal-external.export') }}" id="export-btn">
|
||||||
|
<i class="ki-outline ki-file-down fs-2 me-1"></i>
|
||||||
|
Export to Excel
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Data Table Card -->
|
||||||
|
<div class="card border border-agi-100 card-grid min-w-full" data-datatable="false" data-datatable-page-size="10" data-datatable-state-save="false" id="laporan-hasil-penilaian-jaminan-internal-external-table" data-api-url="{{ route('laporan-hasil-penilaian-jaminan-internal-external.data') }}">
|
||||||
|
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
||||||
|
<h3 class="card-title">
|
||||||
|
Laporan Hasil Penilaian Jaminan Internal & External
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="scrollable-x-auto">
|
||||||
|
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm" data-datatable-table="true">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="w-14">
|
||||||
|
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox"/>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nomor_registrasi">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nomor Registrasi </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_permohonan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Permohonan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="branch">
|
||||||
|
<span class="sort"> <span class="sort-label"> Cabang </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="pemohon">
|
||||||
|
<span class="sort"> <span class="sort-label"> Pemohon </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="cif">
|
||||||
|
<span class="sort"> <span class="sort-label"> CIF </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="name">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Debitur </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jenis_penilaian">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jenis Penilaian </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tujuan_penilaian">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tujuan Penilaian </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jenis_fasilitas_kredit">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jenis Fasilitas Kredit </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jenis_agunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jenis Agunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="alamat_agunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Alamat Agunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="bukti_kepemilikan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Bukti Kepemilikan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_pemilik">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Pemilik </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="luas_tanah">
|
||||||
|
<span class="sort"> <span class="sort-label"> Luas Tanah </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_tanah">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Tanah </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="luas_bangunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Luas Bangunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_bangunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Bangunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_njop">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai NJOP </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_pasar_wajar">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Pasar Wajar </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_likuidasi">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Likuidasi </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_documen_diterima">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Dokumen Diterima </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_spk">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal SPK </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nomor_spk">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nomor SPK </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_rencana_kunjunagn">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Rencana Kunjungan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_kunjungan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Kunjungan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="taggal_delivered">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Delivered </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jangka_waktu_sla">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jangka Waktu SLA </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_laporan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Laporan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_review">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Review </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_penilai">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Penilai </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_team_leader">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Team Leader </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="saran">
|
||||||
|
<span class="sort"> <span class="sort-label"> Saran </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="catatan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Catatan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
<div class="card-footer justify-center md:justify-between flex-col md:flex-row gap-3 text-gray-600 text-2sm font-medium">
|
||||||
|
<div class="flex items-center gap-2">
|
||||||
|
Show
|
||||||
|
<select class="select select-sm w-16" data-datatable-size="true" name="perpage"> </select> per page
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center gap-4">
|
||||||
|
<span data-datatable-info="true"> </span>
|
||||||
|
<div class="pagination" data-datatable-pagination="true">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@push('scripts')
|
||||||
|
<script type="module">
|
||||||
|
const element = document.querySelector('#laporan-hasil-penilaian-jaminan-internal-external-table');
|
||||||
|
const searchInput = document.getElementById('search');
|
||||||
|
const startDateInput = document.getElementById('start_date');
|
||||||
|
const endDateInput = document.getElementById('end_date');
|
||||||
|
const branchFilter = document.getElementById('branch_filter');
|
||||||
|
const penilaiFilter = document.getElementById('penilai_filter');
|
||||||
|
const filterTanggalButton = document.getElementById('filter_tanggal');
|
||||||
|
const exportBtn = document.getElementById('export-btn');
|
||||||
|
|
||||||
|
const apiUrl = element.getAttribute('data-api-url');
|
||||||
|
const dataTableOptions = {
|
||||||
|
apiEndpoint: apiUrl,
|
||||||
|
pageSize: 5,
|
||||||
|
columns: {
|
||||||
|
select: {
|
||||||
|
render: (item, data, context) => {
|
||||||
|
const checkbox = document.createElement('input');
|
||||||
|
checkbox.className = 'checkbox checkbox-sm';
|
||||||
|
checkbox.type = 'checkbox';
|
||||||
|
checkbox.value = data.id.toString();
|
||||||
|
checkbox.setAttribute('data-datatable-row-check', 'true');
|
||||||
|
return checkbox.outerHTML.trim();
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nomor_registrasi: {
|
||||||
|
title: 'Nomor Registrasi',
|
||||||
|
},
|
||||||
|
tanggal_permohonan: {
|
||||||
|
title: 'Tanggal Permohonan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_permohonan ? window.formatTanggalIndonesia(data.tanggal_permohonan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
branch: {
|
||||||
|
title: 'Cabang',
|
||||||
|
},
|
||||||
|
pemohon: {
|
||||||
|
title: 'Pemohon',
|
||||||
|
},
|
||||||
|
cif: {
|
||||||
|
title: 'CIF',
|
||||||
|
},
|
||||||
|
name: {
|
||||||
|
title: 'Nama Debitur',
|
||||||
|
},
|
||||||
|
jenis_penilaian: {
|
||||||
|
title: 'Jenis Penilaian',
|
||||||
|
},
|
||||||
|
tujuan_penilaian: {
|
||||||
|
title: 'Tujuan Penilaian',
|
||||||
|
},
|
||||||
|
jenis_fasilitas_kredit: {
|
||||||
|
title: 'Jenis Fasilitas Kredit',
|
||||||
|
},
|
||||||
|
jenis_agunan: {
|
||||||
|
title: 'Jenis Agunan',
|
||||||
|
},
|
||||||
|
alamat_agunan: {
|
||||||
|
title: 'Alamat Agunan',
|
||||||
|
},
|
||||||
|
bukti_kepemilikan: {
|
||||||
|
title: 'Bukti Kepemilikan',
|
||||||
|
render: (item, data) => {
|
||||||
|
if (data.bukti_kepemilikan) {
|
||||||
|
// Ganti karakter baris baru dengan tag <br> untuk HTML
|
||||||
|
return data.bukti_kepemilikan.split('\n').join('<br>');
|
||||||
|
}
|
||||||
|
return '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nama_pemilik: {
|
||||||
|
title: 'Nama Pemilik',
|
||||||
|
},
|
||||||
|
luas_tanah: {
|
||||||
|
title: 'Luas Tanah',
|
||||||
|
},
|
||||||
|
nilai_tanah: {
|
||||||
|
title: 'Nilai Tanah',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_tanah ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
luas_bangunan: {
|
||||||
|
title: 'Luas Bangunan',
|
||||||
|
},
|
||||||
|
nilai_bangunan: {
|
||||||
|
title: 'Nilai Bangunan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_bangunan ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nilai_njop: {
|
||||||
|
title: 'Nilai NJOP',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_njop ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nilai_pasar_wajar: {
|
||||||
|
title: 'Nilai Pasar Wajar',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_pasar_wajar ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nilai_likuidasi: {
|
||||||
|
title: 'Nilai Likuidasi',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_likuidasi ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_documen_diterima: {
|
||||||
|
title: 'Tanggal Dokumen Diterima',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_documen_diterima ? window.formatTanggalIndonesia(data.tanggal_documen_diterima) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_spk: {
|
||||||
|
title: 'Tanggal SPK',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_spk ? window.formatTanggalIndonesia(data.tanggal_spk) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nomor_spk: {
|
||||||
|
title: 'Nomor SPK',
|
||||||
|
},
|
||||||
|
tanggal_rencana_kunjunagn: {
|
||||||
|
title: 'Tanggal Rencana Kunjungan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_rencana_kunjunagn ? window.formatTanggalIndonesia(data.tanggal_rencana_kunjunagn) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_kunjungan: {
|
||||||
|
title: 'Tanggal Kunjungan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_kunjungan ? window.formatTanggalIndonesia(data.tanggal_kunjungan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
taggal_delivered: {
|
||||||
|
title: 'Tanggal Delivered',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.taggal_delivered ? window.formatTanggalIndonesia(data.taggal_delivered) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
jangka_waktu_sla: {
|
||||||
|
title: 'Jangka Waktu SLA',
|
||||||
|
},
|
||||||
|
tanggal_laporan: {
|
||||||
|
title: 'Tanggal Laporan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_laporan ? window.formatTanggalIndonesia(data.tanggal_laporan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_review: {
|
||||||
|
title: 'Tanggal Review',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_review ? window.formatTanggalIndonesia(data.tanggal_review) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nama_penilai: {
|
||||||
|
title: 'Nama Penilai',
|
||||||
|
},
|
||||||
|
nama_team_leader: {
|
||||||
|
title: 'Nama Team Leader',
|
||||||
|
},
|
||||||
|
saran: {
|
||||||
|
title: 'Saran',
|
||||||
|
},
|
||||||
|
catatan: {
|
||||||
|
title: 'Catatan',
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
let dataTable = new KTDataTable(element, dataTableOptions);
|
||||||
|
|
||||||
|
// Function to apply all filters
|
||||||
|
function applyFilters() {
|
||||||
|
let filters = {};
|
||||||
|
const startDate = startDateInput.value;
|
||||||
|
const endDate = endDateInput.value;
|
||||||
|
const branch = branchFilter.value;
|
||||||
|
const penilai = penilaiFilter.value;
|
||||||
|
|
||||||
|
if (searchInput.value) {
|
||||||
|
filters.search = searchInput.value;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (startDate) {
|
||||||
|
filters.start_date = startDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (endDate) {
|
||||||
|
filters.end_date = endDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (branch) {
|
||||||
|
filters.branch_id = branch;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (penilai) {
|
||||||
|
filters.penilai_id = penilai;
|
||||||
|
}
|
||||||
|
|
||||||
|
dataTable.search(filters);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update export URL with filters
|
||||||
|
function updateExportUrl() {
|
||||||
|
dataTable.goPage(1);
|
||||||
|
let url = new URL(exportBtn.href);
|
||||||
|
|
||||||
|
if (startDateInput.value) {
|
||||||
|
url.searchParams.set('start_date', startDateInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('start_date');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (endDateInput.value) {
|
||||||
|
url.searchParams.set('end_date', endDateInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('end_date');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (branchFilter.value) {
|
||||||
|
url.searchParams.set('branch_id', branchFilter.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('branch_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (penilaiFilter.value) {
|
||||||
|
url.searchParams.set('penilai_id', penilaiFilter.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('penilai_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (searchInput.value) {
|
||||||
|
url.searchParams.set('search', searchInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('search');
|
||||||
|
}
|
||||||
|
|
||||||
|
exportBtn.href = url.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add event listeners for all inputs
|
||||||
|
searchInput.addEventListener('input', () => {
|
||||||
|
applyFilters();
|
||||||
|
updateExportUrl();
|
||||||
|
});
|
||||||
|
|
||||||
|
filterTanggalButton.addEventListener('click', () => {
|
||||||
|
applyFilters();
|
||||||
|
updateExportUrl();
|
||||||
|
});
|
||||||
|
|
||||||
|
// Initial update of export URL
|
||||||
|
updateExportUrl();
|
||||||
|
</script>
|
||||||
|
@endpush
|
||||||
499
resources/views/laporan-biaya/internal.blade.php
Normal file
499
resources/views/laporan-biaya/internal.blade.php
Normal file
@@ -0,0 +1,499 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render('laporan-hasil-penilaian-jaminan-internal-external') }}
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">S
|
||||||
|
<!-- Filter Card -->
|
||||||
|
<div class="card border border-agi-100">
|
||||||
|
<div class="card-header bg-agi-50 py-5">
|
||||||
|
<h3 class="card-title">Filter Laporan</h3>
|
||||||
|
</div>
|
||||||
|
<div class="card-body grid gap-4">
|
||||||
|
<!-- Search field at the top, full width -->
|
||||||
|
<div class="flex flex-col w-full">
|
||||||
|
<label class="text-sm font-medium mb-1">Pencarian</label>
|
||||||
|
<label class="input input-sm">
|
||||||
|
<i class="ki-filled ki-magnifier"></i>
|
||||||
|
<input placeholder="Search Laporan Hasil Penilaian Jaminan Internal & External" id="search" type="text" value="">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Other filter fields in grid layout -->
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4">
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Tanggal Awal</label>
|
||||||
|
<label class="input">
|
||||||
|
<input placeholder="Tanggal Awal" id="start_date" type="date">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Tanggal Akhir</label>
|
||||||
|
<label class="input">
|
||||||
|
<input placeholder="Tanggal Akhir" id="end_date" type="date">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Cabang</label>
|
||||||
|
<select class="select tomselect" id="branch_filter">
|
||||||
|
<option value="">Semua Cabang</option>
|
||||||
|
@foreach(\Modules\Basicdata\Models\Branch::where('status', 1)->get() as $branch)
|
||||||
|
<option value="{{ $branch->id }}">{{ $branch->name }}</option>
|
||||||
|
@endforeach
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Penilai</label>
|
||||||
|
<select class="select tomselect" id="penilai_filter">
|
||||||
|
<option value="">Semua Penilai</option>
|
||||||
|
@foreach(\MOdules\Usermanagement\Models\User::role(['penilai','surveyor'])->get() as $penilai)
|
||||||
|
<option value="{{ $penilai->id }}">{{ $penilai->name }}</option>
|
||||||
|
@endforeach
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Buttons row at the bottom -->
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 gap-4 mt-2">
|
||||||
|
<button class="btn btn-sm btn-primary" id="filter_tanggal">
|
||||||
|
<i class="ki-outline ki-filter fs-2 me-1"></i>
|
||||||
|
Terapkan Filter
|
||||||
|
</button>
|
||||||
|
<a class="btn btn-sm btn-light" href="{{ route('laporan-hasil-penilaian-jaminan-internal-external.export') }}" id="export-btn">
|
||||||
|
<i class="ki-outline ki-file-down fs-2 me-1"></i>
|
||||||
|
Export to Excel
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Data Table Card -->
|
||||||
|
<div class="card border border-agi-100 card-grid min-w-full" data-datatable="false" data-datatable-page-size="10" data-datatable-state-save="false" id="laporan-hasil-penilaian-jaminan-internal-external-table" data-api-url="{{ route('laporan-hasil-penilaian-jaminan-internal-external.data') }}">
|
||||||
|
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
||||||
|
<h3 class="card-title">
|
||||||
|
Laporan Hasil Penilaian Jaminan Internal & External
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="scrollable-x-auto">
|
||||||
|
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm" data-datatable-table="true">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="w-14">
|
||||||
|
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox"/>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nomor_registrasi">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nomor Registrasi </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_permohonan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Permohonan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="branch">
|
||||||
|
<span class="sort"> <span class="sort-label"> Cabang </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="pemohon">
|
||||||
|
<span class="sort"> <span class="sort-label"> Pemohon </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="cif">
|
||||||
|
<span class="sort"> <span class="sort-label"> CIF </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="name">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Debitur </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jenis_penilaian">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jenis Penilaian </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tujuan_penilaian">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tujuan Penilaian </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jenis_fasilitas_kredit">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jenis Fasilitas Kredit </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jenis_agunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jenis Agunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="alamat_agunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Alamat Agunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="bukti_kepemilikan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Bukti Kepemilikan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_pemilik">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Pemilik </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="luas_tanah">
|
||||||
|
<span class="sort"> <span class="sort-label"> Luas Tanah </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_tanah">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Tanah </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="luas_bangunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Luas Bangunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_bangunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Bangunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_njop">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai NJOP </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_pasar_wajar">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Pasar Wajar </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_likuidasi">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Likuidasi </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_documen_diterima">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Dokumen Diterima </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_spk">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal SPK </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nomor_spk">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nomor SPK </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_rencana_kunjunagn">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Rencana Kunjungan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_kunjungan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Kunjungan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="taggal_delivered">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Delivered </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jangka_waktu_sla">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jangka Waktu SLA </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_laporan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Laporan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_review">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Review </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_penilai">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Penilai </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_team_leader">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Team Leader </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="saran">
|
||||||
|
<span class="sort"> <span class="sort-label"> Saran </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="catatan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Catatan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
<div class="card-footer justify-center md:justify-between flex-col md:flex-row gap-3 text-gray-600 text-2sm font-medium">
|
||||||
|
<div class="flex items-center gap-2">
|
||||||
|
Show
|
||||||
|
<select class="select select-sm w-16" data-datatable-size="true" name="perpage"> </select> per page
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center gap-4">
|
||||||
|
<span data-datatable-info="true"> </span>
|
||||||
|
<div class="pagination" data-datatable-pagination="true">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@push('scripts')
|
||||||
|
<script type="module">
|
||||||
|
const element = document.querySelector('#laporan-hasil-penilaian-jaminan-internal-external-table');
|
||||||
|
const searchInput = document.getElementById('search');
|
||||||
|
const startDateInput = document.getElementById('start_date');
|
||||||
|
const endDateInput = document.getElementById('end_date');
|
||||||
|
const branchFilter = document.getElementById('branch_filter');
|
||||||
|
const penilaiFilter = document.getElementById('penilai_filter');
|
||||||
|
const filterTanggalButton = document.getElementById('filter_tanggal');
|
||||||
|
const exportBtn = document.getElementById('export-btn');
|
||||||
|
|
||||||
|
const apiUrl = element.getAttribute('data-api-url');
|
||||||
|
const dataTableOptions = {
|
||||||
|
apiEndpoint: apiUrl,
|
||||||
|
pageSize: 5,
|
||||||
|
columns: {
|
||||||
|
select: {
|
||||||
|
render: (item, data, context) => {
|
||||||
|
const checkbox = document.createElement('input');
|
||||||
|
checkbox.className = 'checkbox checkbox-sm';
|
||||||
|
checkbox.type = 'checkbox';
|
||||||
|
checkbox.value = data.id.toString();
|
||||||
|
checkbox.setAttribute('data-datatable-row-check', 'true');
|
||||||
|
return checkbox.outerHTML.trim();
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nomor_registrasi: {
|
||||||
|
title: 'Nomor Registrasi',
|
||||||
|
},
|
||||||
|
tanggal_permohonan: {
|
||||||
|
title: 'Tanggal Permohonan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_permohonan ? window.formatTanggalIndonesia(data.tanggal_permohonan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
branch: {
|
||||||
|
title: 'Cabang',
|
||||||
|
},
|
||||||
|
pemohon: {
|
||||||
|
title: 'Pemohon',
|
||||||
|
},
|
||||||
|
cif: {
|
||||||
|
title: 'CIF',
|
||||||
|
},
|
||||||
|
name: {
|
||||||
|
title: 'Nama Debitur',
|
||||||
|
},
|
||||||
|
jenis_penilaian: {
|
||||||
|
title: 'Jenis Penilaian',
|
||||||
|
},
|
||||||
|
tujuan_penilaian: {
|
||||||
|
title: 'Tujuan Penilaian',
|
||||||
|
},
|
||||||
|
jenis_fasilitas_kredit: {
|
||||||
|
title: 'Jenis Fasilitas Kredit',
|
||||||
|
},
|
||||||
|
jenis_agunan: {
|
||||||
|
title: 'Jenis Agunan',
|
||||||
|
},
|
||||||
|
alamat_agunan: {
|
||||||
|
title: 'Alamat Agunan',
|
||||||
|
},
|
||||||
|
bukti_kepemilikan: {
|
||||||
|
title: 'Bukti Kepemilikan',
|
||||||
|
render: (item, data) => {
|
||||||
|
if (data.bukti_kepemilikan) {
|
||||||
|
// Ganti karakter baris baru dengan tag <br> untuk HTML
|
||||||
|
return data.bukti_kepemilikan.split('\n').join('<br>');
|
||||||
|
}
|
||||||
|
return '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nama_pemilik: {
|
||||||
|
title: 'Nama Pemilik',
|
||||||
|
},
|
||||||
|
luas_tanah: {
|
||||||
|
title: 'Luas Tanah',
|
||||||
|
},
|
||||||
|
nilai_tanah: {
|
||||||
|
title: 'Nilai Tanah',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_tanah ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
luas_bangunan: {
|
||||||
|
title: 'Luas Bangunan',
|
||||||
|
},
|
||||||
|
nilai_bangunan: {
|
||||||
|
title: 'Nilai Bangunan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_bangunan ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nilai_njop: {
|
||||||
|
title: 'Nilai NJOP',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_njop ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nilai_pasar_wajar: {
|
||||||
|
title: 'Nilai Pasar Wajar',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_pasar_wajar ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nilai_likuidasi: {
|
||||||
|
title: 'Nilai Likuidasi',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_likuidasi ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_documen_diterima: {
|
||||||
|
title: 'Tanggal Dokumen Diterima',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_documen_diterima ? window.formatTanggalIndonesia(data.tanggal_documen_diterima) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_spk: {
|
||||||
|
title: 'Tanggal SPK',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_spk ? window.formatTanggalIndonesia(data.tanggal_spk) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nomor_spk: {
|
||||||
|
title: 'Nomor SPK',
|
||||||
|
},
|
||||||
|
tanggal_rencana_kunjunagn: {
|
||||||
|
title: 'Tanggal Rencana Kunjungan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_rencana_kunjunagn ? window.formatTanggalIndonesia(data.tanggal_rencana_kunjunagn) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_kunjungan: {
|
||||||
|
title: 'Tanggal Kunjungan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_kunjungan ? window.formatTanggalIndonesia(data.tanggal_kunjungan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
taggal_delivered: {
|
||||||
|
title: 'Tanggal Delivered',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.taggal_delivered ? window.formatTanggalIndonesia(data.taggal_delivered) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
jangka_waktu_sla: {
|
||||||
|
title: 'Jangka Waktu SLA',
|
||||||
|
},
|
||||||
|
tanggal_laporan: {
|
||||||
|
title: 'Tanggal Laporan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_laporan ? window.formatTanggalIndonesia(data.tanggal_laporan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_review: {
|
||||||
|
title: 'Tanggal Review',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_review ? window.formatTanggalIndonesia(data.tanggal_review) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nama_penilai: {
|
||||||
|
title: 'Nama Penilai',
|
||||||
|
},
|
||||||
|
nama_team_leader: {
|
||||||
|
title: 'Nama Team Leader',
|
||||||
|
},
|
||||||
|
saran: {
|
||||||
|
title: 'Saran',
|
||||||
|
},
|
||||||
|
catatan: {
|
||||||
|
title: 'Catatan',
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
let dataTable = new KTDataTable(element, dataTableOptions);
|
||||||
|
|
||||||
|
// Function to apply all filters
|
||||||
|
function applyFilters() {
|
||||||
|
let filters = {};
|
||||||
|
const startDate = startDateInput.value;
|
||||||
|
const endDate = endDateInput.value;
|
||||||
|
const branch = branchFilter.value;
|
||||||
|
const penilai = penilaiFilter.value;
|
||||||
|
|
||||||
|
if (searchInput.value) {
|
||||||
|
filters.search = searchInput.value;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (startDate) {
|
||||||
|
filters.start_date = startDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (endDate) {
|
||||||
|
filters.end_date = endDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (branch) {
|
||||||
|
filters.branch_id = branch;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (penilai) {
|
||||||
|
filters.penilai_id = penilai;
|
||||||
|
}
|
||||||
|
|
||||||
|
dataTable.search(filters);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update export URL with filters
|
||||||
|
function updateExportUrl() {
|
||||||
|
dataTable.goPage(1);
|
||||||
|
let url = new URL(exportBtn.href);
|
||||||
|
|
||||||
|
if (startDateInput.value) {
|
||||||
|
url.searchParams.set('start_date', startDateInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('start_date');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (endDateInput.value) {
|
||||||
|
url.searchParams.set('end_date', endDateInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('end_date');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (branchFilter.value) {
|
||||||
|
url.searchParams.set('branch_id', branchFilter.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('branch_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (penilaiFilter.value) {
|
||||||
|
url.searchParams.set('penilai_id', penilaiFilter.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('penilai_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (searchInput.value) {
|
||||||
|
url.searchParams.set('search', searchInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('search');
|
||||||
|
}
|
||||||
|
|
||||||
|
exportBtn.href = url.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add event listeners for all inputs
|
||||||
|
searchInput.addEventListener('input', () => {
|
||||||
|
applyFilters();
|
||||||
|
updateExportUrl();
|
||||||
|
});
|
||||||
|
|
||||||
|
filterTanggalButton.addEventListener('click', () => {
|
||||||
|
applyFilters();
|
||||||
|
updateExportUrl();
|
||||||
|
});
|
||||||
|
|
||||||
|
// Initial update of export URL
|
||||||
|
updateExportUrl();
|
||||||
|
</script>
|
||||||
|
@endpush
|
||||||
480
resources/views/laporan-debiture/index.blade.php
Normal file
480
resources/views/laporan-debiture/index.blade.php
Normal file
@@ -0,0 +1,480 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render('laporan-debiture') }}
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||||
|
<!-- Filter Card -->
|
||||||
|
<div class="card border border-agi-100">
|
||||||
|
<div class="card-header bg-agi-50 py-5">
|
||||||
|
<h3 class="card-title">Filter Laporan Debiture</h3>
|
||||||
|
</div>
|
||||||
|
<div class="card-body grid gap-4">
|
||||||
|
<!-- Search field at the top, full width -->
|
||||||
|
<div class="flex flex-col w-full">
|
||||||
|
<label class="text-sm font-medium mb-1">Pencarian</label>
|
||||||
|
<label class="input input-sm">
|
||||||
|
<i class="ki-filled ki-magnifier"></i>
|
||||||
|
<input placeholder="Search Laporan Debiture " id="search" type="text" value="">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Other filter fields in grid layout -->
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4">
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Tanggal Awal</label>
|
||||||
|
<label class="input">
|
||||||
|
<input placeholder="Tanggal Awal" id="start_date" type="date">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Tanggal Akhir</label>
|
||||||
|
<label class="input">
|
||||||
|
<input placeholder="Tanggal Akhir" id="end_date" type="date">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Debiture</label>
|
||||||
|
<select class="select tomselect" id="debiture_id">
|
||||||
|
<option value="">Semua Debiture</option>
|
||||||
|
@if (isset($debiture))
|
||||||
|
@foreach ($debiture as $item)
|
||||||
|
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
||||||
|
@endforeach
|
||||||
|
@endif
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Buttons row at the bottom -->
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 gap-4 mt-2">
|
||||||
|
<button class="btn btn-sm btn-primary" id="filter_tanggal">
|
||||||
|
<i class="ki-outline ki-filter fs-2 me-1"></i>
|
||||||
|
Terapkan Filter
|
||||||
|
</button>
|
||||||
|
<a class="btn btn-sm btn-light" href="{{ route('laporan-hasil-penilaian-jaminan-internal-external.export') }}" id="export-btn">
|
||||||
|
<i class="ki-outline ki-file-down fs-2 me-1"></i>
|
||||||
|
Export to Excel
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Data Table Card -->
|
||||||
|
<div class="card border border-agi-100 card-grid min-w-full" data-datatable="false" data-datatable-page-size="10" data-datatable-state-save="false" id="laporan-debiture-table" data-api-url="{{ route('laporan-debiture.datatables') }}">
|
||||||
|
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
||||||
|
<h3 class="card-title">
|
||||||
|
Laporan Debiture
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="scrollable-x-auto">
|
||||||
|
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm" data-datatable-table="true">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="w-14">
|
||||||
|
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox"/>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nomor_registrasi">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nomor Registrasi </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_permohonan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Permohonan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="branch">
|
||||||
|
<span class="sort"> <span class="sort-label"> Cabang </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="pemohon">
|
||||||
|
<span class="sort"> <span class="sort-label"> Pemohon </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="cif">
|
||||||
|
<span class="sort"> <span class="sort-label"> CIF </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="name">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Debitur </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jenis_penilaian">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jenis Penilaian </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tujuan_penilaian">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tujuan Penilaian </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jenis_fasilitas_kredit">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jenis Fasilitas Kredit </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jenis_agunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jenis Agunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="alamat_agunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Alamat Agunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="bukti_kepemilikan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Bukti Kepemilikan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_pemilik">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Pemilik </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="luas_tanah">
|
||||||
|
<span class="sort"> <span class="sort-label"> Luas Tanah </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_tanah">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Tanah </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="luas_bangunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Luas Bangunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_bangunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Bangunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_njop">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai NJOP </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_pasar_wajar">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Pasar Wajar </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_likuidasi">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Likuidasi </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_documen_diterima">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Dokumen Diterima </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_spk">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal SPK </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nomor_spk">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nomor SPK </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_rencana_kunjunagn">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Rencana Kunjungan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_kunjungan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Kunjungan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="taggal_delivered">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Delivered </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jangka_waktu_sla">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jangka Waktu SLA </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_laporan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Laporan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_review">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Review </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_penilai">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Penilai </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_team_leader">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Team Leader </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="saran">
|
||||||
|
<span class="sort"> <span class="sort-label"> Saran </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="catatan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Catatan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
<div class="card-footer justify-center md:justify-between flex-col md:flex-row gap-3 text-gray-600 text-2sm font-medium">
|
||||||
|
<div class="flex items-center gap-2">
|
||||||
|
Show
|
||||||
|
<select class="select select-sm w-16" data-datatable-size="true" name="perpage"> </select> per page
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center gap-4">
|
||||||
|
<span data-datatable-info="true"> </span>
|
||||||
|
<div class="pagination" data-datatable-pagination="true">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@push('scripts')
|
||||||
|
<script type="module">
|
||||||
|
const element = document.querySelector('#laporan-debiture-table');
|
||||||
|
const searchInput = document.getElementById('search');
|
||||||
|
const startDateInput = document.getElementById('start_date');
|
||||||
|
const endDateInput = document.getElementById('end_date');
|
||||||
|
const debitureFilter = document.getElementById('debiture_id');
|
||||||
|
const filterTanggalButton = document.getElementById('filter_tanggal');
|
||||||
|
const exportBtn = document.getElementById('export-btn');
|
||||||
|
|
||||||
|
const apiUrl = element.getAttribute('data-api-url');
|
||||||
|
const dataTableOptions = {
|
||||||
|
apiEndpoint: apiUrl,
|
||||||
|
pageSize: 5,
|
||||||
|
columns: {
|
||||||
|
select: {
|
||||||
|
render: (item, data, context) => {
|
||||||
|
const checkbox = document.createElement('input');
|
||||||
|
checkbox.className = 'checkbox checkbox-sm';
|
||||||
|
checkbox.type = 'checkbox';
|
||||||
|
checkbox.value = data.id.toString();
|
||||||
|
checkbox.setAttribute('data-datatable-row-check', 'true');
|
||||||
|
return checkbox.outerHTML.trim();
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nomor_registrasi: {
|
||||||
|
title: 'Nomor Registrasi',
|
||||||
|
},
|
||||||
|
tanggal_permohonan: {
|
||||||
|
title: 'Tanggal Permohonan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_permohonan ? window.formatTanggalIndonesia(data.tanggal_permohonan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
branch: {
|
||||||
|
title: 'Cabang',
|
||||||
|
},
|
||||||
|
pemohon: {
|
||||||
|
title: 'Pemohon',
|
||||||
|
},
|
||||||
|
cif: {
|
||||||
|
title: 'CIF',
|
||||||
|
},
|
||||||
|
name: {
|
||||||
|
title: 'Nama Debitur',
|
||||||
|
},
|
||||||
|
jenis_penilaian: {
|
||||||
|
title: 'Jenis Penilaian',
|
||||||
|
},
|
||||||
|
tujuan_penilaian: {
|
||||||
|
title: 'Tujuan Penilaian',
|
||||||
|
},
|
||||||
|
jenis_fasilitas_kredit: {
|
||||||
|
title: 'Jenis Fasilitas Kredit',
|
||||||
|
},
|
||||||
|
jenis_agunan: {
|
||||||
|
title: 'Jenis Agunan',
|
||||||
|
},
|
||||||
|
alamat_agunan: {
|
||||||
|
title: 'Alamat Agunan',
|
||||||
|
},
|
||||||
|
bukti_kepemilikan: {
|
||||||
|
title: 'Bukti Kepemilikan',
|
||||||
|
render: (item, data) => {
|
||||||
|
if (data.bukti_kepemilikan) {
|
||||||
|
// Ganti karakter baris baru dengan tag <br> untuk HTML
|
||||||
|
return data.bukti_kepemilikan.split('\n').join('<br>');
|
||||||
|
}
|
||||||
|
return '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nama_pemilik: {
|
||||||
|
title: 'Nama Pemilik',
|
||||||
|
},
|
||||||
|
luas_tanah: {
|
||||||
|
title: 'Luas Tanah',
|
||||||
|
},
|
||||||
|
nilai_tanah: {
|
||||||
|
title: 'Nilai Tanah',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_tanah ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
luas_bangunan: {
|
||||||
|
title: 'Luas Bangunan',
|
||||||
|
},
|
||||||
|
nilai_bangunan: {
|
||||||
|
title: 'Nilai Bangunan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_bangunan ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nilai_njop: {
|
||||||
|
title: 'Nilai NJOP',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_njop ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nilai_pasar_wajar: {
|
||||||
|
title: 'Nilai Pasar Wajar',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_pasar_wajar ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nilai_likuidasi: {
|
||||||
|
title: 'Nilai Likuidasi',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_likuidasi ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_documen_diterima: {
|
||||||
|
title: 'Tanggal Dokumen Diterima',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_documen_diterima ? window.formatTanggalIndonesia(data.tanggal_documen_diterima) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_spk: {
|
||||||
|
title: 'Tanggal SPK',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_spk ? window.formatTanggalIndonesia(data.tanggal_spk) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nomor_spk: {
|
||||||
|
title: 'Nomor SPK',
|
||||||
|
},
|
||||||
|
tanggal_rencana_kunjunagn: {
|
||||||
|
title: 'Tanggal Rencana Kunjungan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_rencana_kunjunagn ? window.formatTanggalIndonesia(data.tanggal_rencana_kunjunagn) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_kunjungan: {
|
||||||
|
title: 'Tanggal Kunjungan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_kunjungan ? window.formatTanggalIndonesia(data.tanggal_kunjungan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
taggal_delivered: {
|
||||||
|
title: 'Tanggal Delivered',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.taggal_delivered ? window.formatTanggalIndonesia(data.taggal_delivered) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
jangka_waktu_sla: {
|
||||||
|
title: 'Jangka Waktu SLA',
|
||||||
|
},
|
||||||
|
tanggal_laporan: {
|
||||||
|
title: 'Tanggal Laporan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_laporan ? window.formatTanggalIndonesia(data.tanggal_laporan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_review: {
|
||||||
|
title: 'Tanggal Review',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_review ? window.formatTanggalIndonesia(data.tanggal_review) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nama_penilai: {
|
||||||
|
title: 'Nama Penilai',
|
||||||
|
},
|
||||||
|
nama_team_leader: {
|
||||||
|
title: 'Nama Team Leader',
|
||||||
|
},
|
||||||
|
saran: {
|
||||||
|
title: 'Saran',
|
||||||
|
},
|
||||||
|
catatan: {
|
||||||
|
title: 'Catatan',
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
let dataTable = new KTDataTable(element, dataTableOptions);
|
||||||
|
|
||||||
|
// Function to apply all filters
|
||||||
|
function applyFilters() {
|
||||||
|
let filters = {};
|
||||||
|
const startDate = startDateInput.value;
|
||||||
|
const endDate = endDateInput.value;
|
||||||
|
const debiture = debitureFilter.value;
|
||||||
|
|
||||||
|
if (searchInput.value) {
|
||||||
|
filters.search = searchInput.value;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (startDate) {
|
||||||
|
filters.start_date = startDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (endDate) {
|
||||||
|
filters.end_date = endDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (debiture) {
|
||||||
|
filters.debiture_id = debiture;
|
||||||
|
}
|
||||||
|
|
||||||
|
dataTable.search(filters);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update export URL with filters
|
||||||
|
function updateExportUrl() {
|
||||||
|
dataTable.goPage(1);
|
||||||
|
let url = new URL(exportBtn.href);
|
||||||
|
|
||||||
|
if (startDateInput.value) {
|
||||||
|
url.searchParams.set('start_date', startDateInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('start_date');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (endDateInput.value) {
|
||||||
|
url.searchParams.set('end_date', endDateInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('end_date');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (debitureFilter.value) {
|
||||||
|
url.searchParams.set('debiture_id', debitureFilter.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('debiture_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (searchInput.value) {
|
||||||
|
url.searchParams.set('search', searchInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('search');
|
||||||
|
}
|
||||||
|
|
||||||
|
exportBtn.href = url.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add event listeners for all inputs
|
||||||
|
searchInput.addEventListener('input', () => {
|
||||||
|
applyFilters();
|
||||||
|
updateExportUrl();
|
||||||
|
});
|
||||||
|
|
||||||
|
filterTanggalButton.addEventListener('click', () => {
|
||||||
|
applyFilters();
|
||||||
|
updateExportUrl();
|
||||||
|
});
|
||||||
|
|
||||||
|
// Initial update of export URL
|
||||||
|
updateExportUrl();
|
||||||
|
</script>
|
||||||
|
@endpush
|
||||||
89
resources/views/laporan-monitoring/index.blade.php
Normal file
89
resources/views/laporan-monitoring/index.blade.php
Normal file
@@ -0,0 +1,89 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render('laporan-monitoring') }}
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||||
|
<!-- Filter Card -->
|
||||||
|
|
||||||
|
<!-- Data Table Card -->
|
||||||
|
<div class="card border border-agi-100 card-grid min-w-full" data-datatable="false" data-datatable-page-size="10"
|
||||||
|
data-datatable-state-save="false" id="laporan-hasil-penilaian-jaminan-internal-external-table"
|
||||||
|
data-api-url="{{ route('laporan-hasil-penilaian-jaminan-internal-external.data') }}">
|
||||||
|
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
||||||
|
<h3 class="card-title">
|
||||||
|
Rekap Progres Pengerjaan Laporan Penilai
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="scrollable-x-auto">
|
||||||
|
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm"
|
||||||
|
data-datatable-table="true">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="w-14">
|
||||||
|
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox" />
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_penilai">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Penilai </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="total_task">
|
||||||
|
<span class="sort"> <span class="sort-label"> Total Task </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="actions">
|
||||||
|
<span class="sort"> <span class="sort-label"> Aksi </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
@php
|
||||||
|
$sortedTeamsActivity = $result['teamsActivity']->sortBy(function ($item) {
|
||||||
|
return $item->team->regions->penilaiTeam
|
||||||
|
->filter(function ($penilaiTeam) {
|
||||||
|
$permohonan = optional($penilaiTeam->penilaian)->permohonan;
|
||||||
|
return $permohonan !== null;
|
||||||
|
})
|
||||||
|
->count();
|
||||||
|
});
|
||||||
|
@endphp
|
||||||
|
<tbody>
|
||||||
|
@foreach ($sortedTeamsActivity as $teamActivity)
|
||||||
|
@php
|
||||||
|
$totalTask = countPermohonanForUser($teamActivity->user->id);
|
||||||
|
@endphp
|
||||||
|
<tr>
|
||||||
|
<td class="w-14">
|
||||||
|
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox" />
|
||||||
|
</td>
|
||||||
|
<td class="min-w-[150px]">
|
||||||
|
{{ $teamActivity->user->name }}
|
||||||
|
</td>
|
||||||
|
<td class="min-w-[150px]">
|
||||||
|
{{ $totalTask }}
|
||||||
|
</td>
|
||||||
|
|
||||||
|
<td class="min-w-[150px]">
|
||||||
|
<a href="{{ route('laporan-monitoring.show', $teamActivity->user->id) }}"
|
||||||
|
class="btn btn-sm btn-primary">
|
||||||
|
<i class="ki-outline ki-eye"></i>
|
||||||
|
Lihat
|
||||||
|
</a>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
@endforeach
|
||||||
|
|
||||||
|
</tbody>
|
||||||
|
|
||||||
|
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@endsection
|
||||||
211
resources/views/laporan-monitoring/show.blade.php
Normal file
211
resources/views/laporan-monitoring/show.blade.php
Normal file
@@ -0,0 +1,211 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render(request()->route()->getName()) }}
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<div class="grid">
|
||||||
|
<div class="card border border-agi-100 card-grid min-w-full" data-datatable="false" data-datatable-page-size="10"
|
||||||
|
data-datatable-state-save="false" id="laporan-penilai-table"
|
||||||
|
data-api-url="{{ route('laporan-monitoring.datatables', ['id' => $id]) }}">
|
||||||
|
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
||||||
|
<h3 class="card-title">
|
||||||
|
Daftar Penilaian {{ $nama_penilai ?? '' }}
|
||||||
|
</h3>
|
||||||
|
<div class="flex flex-wrap gap-2 lg:gap-5">
|
||||||
|
|
||||||
|
<div class="flex flex-wrap gap-2.5">
|
||||||
|
<div class="h-[24px] border border-r-gray-200"></div>
|
||||||
|
|
||||||
|
<a class="btn btn-sm btn-light" href=""> Export to Excel </a>
|
||||||
|
|
||||||
|
<a class="btn btn-sm btn-info" href="{{ route('laporan-monitoring.index') }}">
|
||||||
|
<i class="ki-duotone ki-arrow-left fs-2"></i>
|
||||||
|
Back</a>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="scrollable-x-auto">
|
||||||
|
<table class="table table-auto align-middle text-gray-700 font-medium text-sm mb-4"
|
||||||
|
data-datatable-table="true">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="min-w-[100px]">Nama Debitur</th>
|
||||||
|
<th class="min-w-[100px]">Tujuan Penilaian</th>
|
||||||
|
<th class="min-w-[100px]">Status Bayar</th>
|
||||||
|
<th class="min-w-[100px]">Jenis Asset</th>
|
||||||
|
<th class="min-w-[100px]">Penugasan</th>
|
||||||
|
<th class="min-w-[100px]">Jenis Report</th>
|
||||||
|
<th class="min-w-[100px]">Tgl Register</th>
|
||||||
|
<th class="min-w-[100px]">Tgl Assign</th>
|
||||||
|
<th class="min-w-[100px]">Tgl Kunjungan</th>
|
||||||
|
<th class="min-w-[100px]">Progress</th>
|
||||||
|
<th class="min-w-[100px]">SLA Laporan</th>
|
||||||
|
<th class="min-w-[100px]">SLA Paparan</th>
|
||||||
|
<th class="min-w-[100px]">Approve</th>
|
||||||
|
<th class="min-w-[50px] text-center">Keterangan</th>
|
||||||
|
<th class="min-w-[50px] text-center">Action</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
<div
|
||||||
|
class="card-footer justify-center md:justify-between flex-col md:flex-row gap-3 text-gray-600 text-2sm font-medium">
|
||||||
|
<div class="flex items-center gap-2">
|
||||||
|
Show
|
||||||
|
<select class="select select-sm w-16" data-datatable-size="true" name="perpage"></select> per page
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center gap-4">
|
||||||
|
<span data-datatable-info="true"></span>
|
||||||
|
<div class="pagination" data-datatable-pagination="true"></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@push('scripts')
|
||||||
|
<script type="module">
|
||||||
|
const element = document.querySelector('#laporan-penilai-table');
|
||||||
|
const apiUrl = element.getAttribute('data-api-url');
|
||||||
|
|
||||||
|
const dataTableOptions = {
|
||||||
|
apiEndpoint: apiUrl,
|
||||||
|
pageSize: 5,
|
||||||
|
order: [{
|
||||||
|
column: 'nomor_registrasi',
|
||||||
|
dir: 'asc'
|
||||||
|
}],
|
||||||
|
columns: {
|
||||||
|
nama_debitur: {
|
||||||
|
title: 'Nama Debitur',
|
||||||
|
render: (item, data) => {
|
||||||
|
return `${data.permohonan.debiture?.name}`
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tujuan_penilaian: {
|
||||||
|
title: 'Tujuan Penilaian',
|
||||||
|
render: (item, data) => {
|
||||||
|
return `${data.permohonan.tujuan_penilaian?.name || ''}`;
|
||||||
|
},
|
||||||
|
},
|
||||||
|
status_bayar: {
|
||||||
|
title: 'Status Bayar',
|
||||||
|
render: (item, data) => {
|
||||||
|
const status = data.permohonan.status_bayar.replace(
|
||||||
|
/_/g,
|
||||||
|
' ');
|
||||||
|
const statusClass = data.permohonan.status_bayar ===
|
||||||
|
'belum_bayar' ? 'text-red-600' :
|
||||||
|
'text-green-600';
|
||||||
|
return `<span class="badge badge-sm badge-default font-bold ${statusClass} uppercase">
|
||||||
|
${status}
|
||||||
|
</span>`;
|
||||||
|
},
|
||||||
|
},
|
||||||
|
jenis_asset: {
|
||||||
|
title: 'Jenis Asset',
|
||||||
|
render: (item, data) =>
|
||||||
|
`${data.permohonan.debiture?.documents?.map(d => d.jenis_jaminan.name) || ''}`,
|
||||||
|
},
|
||||||
|
penugasan: {
|
||||||
|
title: 'Penugasan',
|
||||||
|
render: (item, data) => {
|
||||||
|
|
||||||
|
const roles = data.user_penilai?.map(d => d.role).join(
|
||||||
|
'<br>') || '-';
|
||||||
|
return roles;
|
||||||
|
},
|
||||||
|
},
|
||||||
|
jenis_report: {
|
||||||
|
title: 'Jenis Report',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.permohonan.penilai?.type_penilai || '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
register: {
|
||||||
|
title: 'Register',
|
||||||
|
render: (item, data) =>
|
||||||
|
`${window.formatTanggalIndonesia(data.permohonan.created_at) || ''}`,
|
||||||
|
|
||||||
|
},
|
||||||
|
assign: {
|
||||||
|
title: 'Assign',
|
||||||
|
render: (item, data) =>
|
||||||
|
`${window.formatTanggalIndonesia(data.created_at)}`,
|
||||||
|
},
|
||||||
|
tanggal_kunjungan: {
|
||||||
|
title: 'Tgl Kunjungan',
|
||||||
|
render: (item, data) =>
|
||||||
|
`${window.formatTanggalIndonesia(data.waktu_penilaian) || ''}`,
|
||||||
|
},
|
||||||
|
progress: {
|
||||||
|
title: 'Progress',
|
||||||
|
render: (item, data) => {
|
||||||
|
return `<span class="badge badge-sm badge-default uppercase flex justify-center ">${data.permohonan.status}</span>`;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// tanggal kunjungan h+2 jika plafon di
|
||||||
|
due_date: {
|
||||||
|
title: 'Due Date',
|
||||||
|
render: (item, data) => {
|
||||||
|
if (!data.due_date_sla) {
|
||||||
|
return ``;
|
||||||
|
}
|
||||||
|
return `${window.formatTanggalIndonesia(data.due_date_sla)}`;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
due_date: {
|
||||||
|
title: 'Due Date SLA',
|
||||||
|
render: (item, data) => {
|
||||||
|
if (!data.due_date_sla) {
|
||||||
|
return `-`;
|
||||||
|
}
|
||||||
|
return `${window.formatTanggalIndonesia(data.due_date_sla)}`;
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
|
paparan: {
|
||||||
|
title: 'Paparan',
|
||||||
|
render: (item, data) => {
|
||||||
|
if (!data.due_date_sla) {
|
||||||
|
return `-`;
|
||||||
|
}
|
||||||
|
return `${window.formatTanggalIndonesia(data.paparan)}`;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
approve: {
|
||||||
|
title: 'Approve',
|
||||||
|
render: (item, data) => {
|
||||||
|
// Gabungkan nama dengan <br> untuk pemisah baris baru
|
||||||
|
let dataHtml = `
|
||||||
|
${data.permohonan?.approve_so?.name || ''}
|
||||||
|
<br>
|
||||||
|
${data.permohonan?.approve_eo?.name || ''}
|
||||||
|
<br>
|
||||||
|
${data.permohonan?.approve_dd?.name || ''}
|
||||||
|
`;
|
||||||
|
return dataHtml;
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
|
keterangan: {
|
||||||
|
title: 'Keterangan',
|
||||||
|
render: (item, data) => `${data.keterangan || ''}`,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
let dataTable = new KTDataTable(element, dataTableOptions);
|
||||||
|
|
||||||
|
</script>
|
||||||
|
@endpush
|
||||||
295
resources/views/laporan-sla-penilai/index.blade.php
Normal file
295
resources/views/laporan-sla-penilai/index.blade.php
Normal file
@@ -0,0 +1,295 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render('laporan-sla-penilai') }}
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||||
|
<!-- Filter Card -->
|
||||||
|
<div class="card border border-agi-100">
|
||||||
|
<div class="card-header bg-agi-50 py-5">
|
||||||
|
<h3 class="card-title">Filter Laporan SLA Penilai</h3>
|
||||||
|
</div>
|
||||||
|
<div class="card-body grid gap-4">
|
||||||
|
<!-- Search field at the top, full width -->
|
||||||
|
<div class="flex flex-col w-full">
|
||||||
|
<label class="text-sm font-medium mb-1">Pencarian</label>
|
||||||
|
<label class="input input-sm">
|
||||||
|
<i class="ki-filled ki-magnifier"></i>
|
||||||
|
<input placeholder="Search Laporan Penilaian Jaminan" id="search" type="text" value="">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Other filter fields in grid layout -->
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4">
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Tanggal Awal</label>
|
||||||
|
<label class="input">
|
||||||
|
<input placeholder="Tanggal Awal" id="start_date" type="date">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Tanggal Akhir</label>
|
||||||
|
<label class="input">
|
||||||
|
<input placeholder="Tanggal Akhir" id="end_date" type="date">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Penilai</label>
|
||||||
|
<select class="select tomselect" id="penilai_filter">
|
||||||
|
<option value="">Semua Penilai</option>
|
||||||
|
@foreach(\MOdules\Usermanagement\Models\User::role(['penilai','surveyor'])->get() as $penilai)
|
||||||
|
<option value="{{ $penilai->id }}">{{ $penilai->name }}</option>
|
||||||
|
@endforeach
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Buttons row at the bottom -->
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 gap-4 mt-2">
|
||||||
|
<button class="btn btn-sm btn-primary" id="filter_tanggal">
|
||||||
|
<i class="ki-outline ki-filter fs-2 me-1"></i>
|
||||||
|
Terapkan Filter
|
||||||
|
</button>
|
||||||
|
<a class="btn btn-sm btn-light" href="{{ route('laporan-hasil-penilaian-jaminan-internal-external.export') }}" id="export-btn">
|
||||||
|
<i class="ki-outline ki-file-down fs-2 me-1"></i>
|
||||||
|
Export to Excel
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Data Table Card -->
|
||||||
|
<div class="card border border-agi-100 card-grid min-w-full" data-datatable="false" data-datatable-page-size="10" data-datatable-state-save="false" id="laporan-sla-penilai-table" data-api-url="{{ route('laporan-sla-penilai.datatables') }}">
|
||||||
|
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
||||||
|
<h3 class="card-title">
|
||||||
|
Laporan SLA Penilai
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="scrollable-x-auto">
|
||||||
|
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm" data-datatable-table="true">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="w-14">
|
||||||
|
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox"/>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nomor_registrasi">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nomor Registrasi </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_penilai">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Penilai </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_permohonan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Permohonan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="branch">
|
||||||
|
<span class="sort"> <span class="sort-label"> Cabang </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="name">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Debitur </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tujuan_penilaian">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tujuan Penilaian </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jenis_agunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Penilaian</span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_laporan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Dokuemen </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_review">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Approval </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_review">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jangka Waktu </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
<div class="card-footer justify-center md:justify-between flex-col md:flex-row gap-3 text-gray-600 text-2sm font-medium">
|
||||||
|
<div class="flex items-center gap-2">
|
||||||
|
Show
|
||||||
|
<select class="select select-sm w-16" data-datatable-size="true" name="perpage"> </select> per
|
||||||
|
page
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center gap-4">
|
||||||
|
<span data-datatable-info="true"> </span>
|
||||||
|
<div class="pagination" data-datatable-pagination="true">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@push('scripts')
|
||||||
|
<script type="module">
|
||||||
|
const element = document.querySelector('#laporan-sla-penilai-table');
|
||||||
|
const searchInput = document.getElementById('search');
|
||||||
|
const startDateInput = document.getElementById('start_date');
|
||||||
|
const endDateInput = document.getElementById('end_date');
|
||||||
|
const filterTanggalButton = document.getElementById('filter_tanggal');
|
||||||
|
const penilaiFilter = document.getElementById('penilai_filter');
|
||||||
|
const exportBtn = document.getElementById('export-btn');
|
||||||
|
|
||||||
|
const apiUrl = element.getAttribute('data-api-url');
|
||||||
|
const dataTableOptions = {
|
||||||
|
apiEndpoint: apiUrl,
|
||||||
|
pageSize: 5,
|
||||||
|
columns: {
|
||||||
|
select: {
|
||||||
|
render: (item, data, context) => {
|
||||||
|
const checkbox = document.createElement('input');
|
||||||
|
checkbox.className = 'checkbox checkbox-sm';
|
||||||
|
checkbox.type = 'checkbox';
|
||||||
|
checkbox.value = data.id.toString();
|
||||||
|
checkbox.setAttribute('data-datatable-row-check', 'true');
|
||||||
|
return checkbox.outerHTML.trim();
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nomor_registrasi: {
|
||||||
|
title: 'Nomor Registrasi',
|
||||||
|
},
|
||||||
|
nama_penilai: {
|
||||||
|
title: 'Nama Penilai',
|
||||||
|
},
|
||||||
|
tanggal_permohonan: {
|
||||||
|
title: 'Tanggal Permohonan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_permohonan ? window.formatTanggalIndonesia(data.tanggal_permohonan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
branch: {
|
||||||
|
title: 'Cabang',
|
||||||
|
},
|
||||||
|
name: {
|
||||||
|
title: 'Nama Debitur',
|
||||||
|
},
|
||||||
|
|
||||||
|
tujuan_penilaian: {
|
||||||
|
title: 'Tujuan Penilaian',
|
||||||
|
},
|
||||||
|
jenis_agunan: {
|
||||||
|
title: 'Jenis Agunan',
|
||||||
|
},
|
||||||
|
|
||||||
|
tanggal_laporan: {
|
||||||
|
title: 'Tanggal Laporan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_laporan ? window.formatTanggalIndonesia(data.tanggal_laporan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_review: {
|
||||||
|
title: 'Tanggal Review',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_review ? window.formatTanggalIndonesia(data.tanggal_review) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
jangka_waktu: {
|
||||||
|
title: 'Jangka Waktu',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.jangka_waktu ?? '3';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
let dataTable = new KTDataTable(element, dataTableOptions);
|
||||||
|
|
||||||
|
// Function to apply all filters
|
||||||
|
function applyFilters() {
|
||||||
|
let filters = {};
|
||||||
|
const startDate = startDateInput.value;
|
||||||
|
const endDate = endDateInput.value;
|
||||||
|
const penilai = penilaiFilter.value;
|
||||||
|
|
||||||
|
if (searchInput.value) {
|
||||||
|
filters.search = searchInput.value;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (startDate) {
|
||||||
|
filters.start_date = startDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (endDate) {
|
||||||
|
filters.end_date = endDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (penilai) {
|
||||||
|
filters.penilai_id = penilai;
|
||||||
|
}
|
||||||
|
|
||||||
|
dataTable.search(filters);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update export URL with filters
|
||||||
|
function updateExportUrl() {
|
||||||
|
let url = new URL(exportBtn.href);
|
||||||
|
|
||||||
|
if (startDateInput.value) {
|
||||||
|
url.searchParams.set('start_date', startDateInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('start_date');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (endDateInput.value) {
|
||||||
|
url.searchParams.set('end_date', endDateInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('end_date');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (searchInput.value) {
|
||||||
|
url.searchParams.set('search', searchInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('search');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (penilaiFilter.value) {
|
||||||
|
url.searchParams.set('penilai_id', penilaiFilter.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('penilai_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
exportBtn.href = url.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add event listeners for all inputs
|
||||||
|
searchInput.addEventListener('input', () => {
|
||||||
|
applyFilters();
|
||||||
|
updateExportUrl();
|
||||||
|
});
|
||||||
|
|
||||||
|
filterTanggalButton.addEventListener('click', () => {
|
||||||
|
applyFilters();
|
||||||
|
updateExportUrl();
|
||||||
|
});
|
||||||
|
|
||||||
|
// Initial update of export URL
|
||||||
|
updateExportUrl();
|
||||||
|
</script>
|
||||||
|
@endpush
|
||||||
518
resources/views/laporan-user/index.blade.php
Normal file
518
resources/views/laporan-user/index.blade.php
Normal file
@@ -0,0 +1,518 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render('laporan-user') }}
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||||
|
<!-- Filter Card -->
|
||||||
|
<div class="card border border-agi-100">
|
||||||
|
<div class="card-header bg-agi-50 py-5">
|
||||||
|
<h3 class="card-title"> Laporan User Pemohon</h3>
|
||||||
|
</div>
|
||||||
|
<div class="card-body grid gap-4">
|
||||||
|
<!-- Search field at the top, full width -->
|
||||||
|
<div class="flex flex-col w-full">
|
||||||
|
<label class="text-sm font-medium mb-1">Pencarian</label>
|
||||||
|
<label class="input input-sm">
|
||||||
|
<i class="ki-filled ki-magnifier"></i>
|
||||||
|
<input placeholder="Search Laporan User" id="search" type="text" value="">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Other filter fields in grid layout -->
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4">
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Tanggal Awal</label>
|
||||||
|
<label class="input">
|
||||||
|
<input placeholder="Tanggal Awal" id="start_date" type="date">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">Tanggal Akhir</label>
|
||||||
|
<label class="input">
|
||||||
|
<input placeholder="Tanggal Akhir" id="end_date" type="date">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-col">
|
||||||
|
<label class="text-base font-medium mb-1">User</label>
|
||||||
|
<select class="select tomselect" id="user_id" name="user_id">
|
||||||
|
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Buttons row at the bottom -->
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 gap-4 mt-2">
|
||||||
|
<button class="btn btn-sm btn-primary" id="filter_tanggal">
|
||||||
|
<i class="ki-outline ki-filter fs-2 me-1"></i>
|
||||||
|
Terapkan Filter
|
||||||
|
</button>
|
||||||
|
<a class="btn btn-sm btn-light" href="{{ route('laporan-hasil-penilaian-jaminan-internal-external.export') }}" id="export-btn">
|
||||||
|
<i class="ki-outline ki-file-down fs-2 me-1"></i>
|
||||||
|
Export to Excel
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Data Table Card -->
|
||||||
|
<div class="card border border-agi-100 card-grid min-w-full" data-datatable="false" data-datatable-page-size="10" data-datatable-state-save="false" id="laporan-user-table" data-api-url="{{ route('laporan-user.datatables') }}">
|
||||||
|
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
||||||
|
<h3 class="card-title">
|
||||||
|
Laporan User Pemohon
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="scrollable-x-auto">
|
||||||
|
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm" data-datatable-table="true">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="w-14">
|
||||||
|
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox"/>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nomor_registrasi">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nomor Registrasi </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_permohonan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Permohonan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="branch">
|
||||||
|
<span class="sort"> <span class="sort-label"> Cabang </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="pemohon">
|
||||||
|
<span class="sort"> <span class="sort-label"> Pemohon </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="cif">
|
||||||
|
<span class="sort"> <span class="sort-label"> CIF </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="name">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Debitur </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jenis_penilaian">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jenis Penilaian </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tujuan_penilaian">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tujuan Penilaian </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jenis_fasilitas_kredit">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jenis Fasilitas Kredit </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jenis_agunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jenis Agunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="alamat_agunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Alamat Agunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="bukti_kepemilikan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Bukti Kepemilikan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_pemilik">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Pemilik </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="luas_tanah">
|
||||||
|
<span class="sort"> <span class="sort-label"> Luas Tanah </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_tanah">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Tanah </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="luas_bangunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Luas Bangunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_bangunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Bangunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_njop">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai NJOP </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_pasar_wajar">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Pasar Wajar </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_likuidasi">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Likuidasi </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_documen_diterima">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Dokumen Diterima </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_spk">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal SPK </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nomor_spk">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nomor SPK </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_rencana_kunjunagn">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Rencana Kunjungan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_kunjungan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Kunjungan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="taggal_delivered">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Delivered </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="jangka_waktu_sla">
|
||||||
|
<span class="sort"> <span class="sort-label"> Jangka Waktu SLA </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_laporan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Laporan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_review">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Review </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_penilai">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Penilai </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nama_team_leader">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nama Team Leader </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="saran">
|
||||||
|
<span class="sort"> <span class="sort-label"> Saran </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="catatan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Catatan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
<div class="card-footer justify-center md:justify-between flex-col md:flex-row gap-3 text-gray-600 text-2sm font-medium">
|
||||||
|
<div class="flex items-center gap-2">
|
||||||
|
Show
|
||||||
|
<select class="select select-sm w-16" data-datatable-size="true" name="perpage"> </select> per page
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center gap-4">
|
||||||
|
<span data-datatable-info="true"> </span>
|
||||||
|
<div class="pagination" data-datatable-pagination="true">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@push('scripts')
|
||||||
|
<script type="module">
|
||||||
|
const element = document.querySelector('#laporan-user-table');
|
||||||
|
const searchInput = document.getElementById('search');
|
||||||
|
const startDateInput = document.getElementById('start_date');
|
||||||
|
const endDateInput = document.getElementById('end_date');
|
||||||
|
const userFilter = document.getElementById('user_id');
|
||||||
|
const filterTanggalButton = document.getElementById('filter_tanggal');
|
||||||
|
const exportBtn = document.getElementById('export-btn');
|
||||||
|
|
||||||
|
const apiUrl = element.getAttribute('data-api-url');
|
||||||
|
const dataTableOptions = {
|
||||||
|
apiEndpoint: apiUrl,
|
||||||
|
pageSize: 5,
|
||||||
|
columns: {
|
||||||
|
select: {
|
||||||
|
render: (item, data, context) => {
|
||||||
|
const checkbox = document.createElement('input');
|
||||||
|
checkbox.className = 'checkbox checkbox-sm';
|
||||||
|
checkbox.type = 'checkbox';
|
||||||
|
checkbox.value = data.id.toString();
|
||||||
|
checkbox.setAttribute('data-datatable-row-check', 'true');
|
||||||
|
return checkbox.outerHTML.trim();
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nomor_registrasi: {
|
||||||
|
title: 'Nomor Registrasi',
|
||||||
|
},
|
||||||
|
tanggal_permohonan: {
|
||||||
|
title: 'Tanggal Permohonan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_permohonan ? window.formatTanggalIndonesia(data.tanggal_permohonan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
branch: {
|
||||||
|
title: 'Cabang',
|
||||||
|
},
|
||||||
|
pemohon: {
|
||||||
|
title: 'Pemohon',
|
||||||
|
},
|
||||||
|
cif: {
|
||||||
|
title: 'CIF',
|
||||||
|
},
|
||||||
|
name: {
|
||||||
|
title: 'Nama Debitur',
|
||||||
|
},
|
||||||
|
jenis_penilaian: {
|
||||||
|
title: 'Jenis Penilaian',
|
||||||
|
},
|
||||||
|
tujuan_penilaian: {
|
||||||
|
title: 'Tujuan Penilaian',
|
||||||
|
},
|
||||||
|
jenis_fasilitas_kredit: {
|
||||||
|
title: 'Jenis Fasilitas Kredit',
|
||||||
|
},
|
||||||
|
jenis_agunan: {
|
||||||
|
title: 'Jenis Agunan',
|
||||||
|
},
|
||||||
|
alamat_agunan: {
|
||||||
|
title: 'Alamat Agunan',
|
||||||
|
},
|
||||||
|
bukti_kepemilikan: {
|
||||||
|
title: 'Bukti Kepemilikan',
|
||||||
|
render: (item, data) => {
|
||||||
|
if (data.bukti_kepemilikan) {
|
||||||
|
// Ganti karakter baris baru dengan tag <br> untuk HTML
|
||||||
|
return data.bukti_kepemilikan.split('\n').join('<br>');
|
||||||
|
}
|
||||||
|
return '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nama_pemilik: {
|
||||||
|
title: 'Nama Pemilik',
|
||||||
|
},
|
||||||
|
luas_tanah: {
|
||||||
|
title: 'Luas Tanah',
|
||||||
|
},
|
||||||
|
nilai_tanah: {
|
||||||
|
title: 'Nilai Tanah',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_tanah ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
luas_bangunan: {
|
||||||
|
title: 'Luas Bangunan',
|
||||||
|
},
|
||||||
|
nilai_bangunan: {
|
||||||
|
title: 'Nilai Bangunan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_bangunan ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nilai_njop: {
|
||||||
|
title: 'Nilai NJOP',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_njop ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nilai_pasar_wajar: {
|
||||||
|
title: 'Nilai Pasar Wajar',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_pasar_wajar ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nilai_likuidasi: {
|
||||||
|
title: 'Nilai Likuidasi',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.nilai_likuidasi ?? '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_documen_diterima: {
|
||||||
|
title: 'Tanggal Dokumen Diterima',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_documen_diterima ? window.formatTanggalIndonesia(data.tanggal_documen_diterima) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_spk: {
|
||||||
|
title: 'Tanggal SPK',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_spk ? window.formatTanggalIndonesia(data.tanggal_spk) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nomor_spk: {
|
||||||
|
title: 'Nomor SPK',
|
||||||
|
},
|
||||||
|
tanggal_rencana_kunjunagn: {
|
||||||
|
title: 'Tanggal Rencana Kunjungan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_rencana_kunjunagn ? window.formatTanggalIndonesia(data.tanggal_rencana_kunjunagn) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_kunjungan: {
|
||||||
|
title: 'Tanggal Kunjungan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_kunjungan ? window.formatTanggalIndonesia(data.tanggal_kunjungan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
taggal_delivered: {
|
||||||
|
title: 'Tanggal Delivered',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.taggal_delivered ? window.formatTanggalIndonesia(data.taggal_delivered) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
jangka_waktu_sla: {
|
||||||
|
title: 'Jangka Waktu SLA',
|
||||||
|
},
|
||||||
|
tanggal_laporan: {
|
||||||
|
title: 'Tanggal Laporan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_laporan ? window.formatTanggalIndonesia(data.tanggal_laporan) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tanggal_review: {
|
||||||
|
title: 'Tanggal Review',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.tanggal_review ? window.formatTanggalIndonesia(data.tanggal_review) : '-';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nama_penilai: {
|
||||||
|
title: 'Nama Penilai',
|
||||||
|
},
|
||||||
|
nama_team_leader: {
|
||||||
|
title: 'Nama Team Leader',
|
||||||
|
},
|
||||||
|
saran: {
|
||||||
|
title: 'Saran',
|
||||||
|
},
|
||||||
|
catatan: {
|
||||||
|
title: 'Catatan',
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
let dataTable = new KTDataTable(element, dataTableOptions);
|
||||||
|
|
||||||
|
// Function to apply all filters
|
||||||
|
function applyFilters() {
|
||||||
|
let filters = {};
|
||||||
|
const startDate = startDateInput.value;
|
||||||
|
const endDate = endDateInput.value;
|
||||||
|
const user_id = userFilter.value;
|
||||||
|
|
||||||
|
|
||||||
|
if (searchInput.value) {
|
||||||
|
filters.search = searchInput.value;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (startDate) {
|
||||||
|
filters.start_date = startDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (endDate) {
|
||||||
|
filters.end_date = endDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (user_id) {
|
||||||
|
filters.user_id = user_id;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
dataTable.search(filters);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update export URL with filters
|
||||||
|
function updateExportUrl() {
|
||||||
|
dataTable.goPage(1);
|
||||||
|
let url = new URL(exportBtn.href);
|
||||||
|
|
||||||
|
if (startDateInput.value) {
|
||||||
|
url.searchParams.set('start_date', startDateInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('start_date');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (endDateInput.value) {
|
||||||
|
url.searchParams.set('end_date', endDateInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('end_date');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (userFilter.value) {
|
||||||
|
url.searchParams.set('user_id', userFilter.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('user_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (searchInput.value) {
|
||||||
|
url.searchParams.set('search', searchInput.value);
|
||||||
|
} else {
|
||||||
|
url.searchParams.delete('search');
|
||||||
|
}
|
||||||
|
|
||||||
|
exportBtn.href = url.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add event listeners for all inputs
|
||||||
|
searchInput.addEventListener('input', () => {
|
||||||
|
applyFilters();
|
||||||
|
updateExportUrl();
|
||||||
|
});
|
||||||
|
|
||||||
|
filterTanggalButton.addEventListener('click', () => {
|
||||||
|
applyFilters();
|
||||||
|
updateExportUrl();
|
||||||
|
});
|
||||||
|
|
||||||
|
// Initial update of export URL
|
||||||
|
updateExportUrl();
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
document.addEventListener('DOMContentLoaded', function() {
|
||||||
|
let userSelect = document.querySelector('#user_id');
|
||||||
|
|
||||||
|
if (userSelect) {
|
||||||
|
// Jika sudah ada instance TomSelect, destroy dulu
|
||||||
|
if (userSelect.tomselect) {
|
||||||
|
userSelect.tomselect.destroy();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Inisialisasi TomSelect dengan konfigurasi yang benar
|
||||||
|
new TomSelect(userSelect, {
|
||||||
|
valueField: 'id',
|
||||||
|
labelField: 'name',
|
||||||
|
searchField: 'name',
|
||||||
|
placeholder: 'Pilih User',
|
||||||
|
load: function(query, callback) {
|
||||||
|
if (!query.length) return callback();
|
||||||
|
|
||||||
|
$.ajax({
|
||||||
|
url: "{{ route('laporan-user.api.user-pemohon') }}",
|
||||||
|
method: 'GET',
|
||||||
|
data: {
|
||||||
|
search: query
|
||||||
|
},
|
||||||
|
success: function(response) {
|
||||||
|
console.log('Response data:', response);
|
||||||
|
callback(response);
|
||||||
|
},
|
||||||
|
error: function() {
|
||||||
|
callback();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
@endpush
|
||||||
58
resources/views/rekap-harian-so/index.blade.php
Normal file
58
resources/views/rekap-harian-so/index.blade.php
Normal file
@@ -0,0 +1,58 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render('rekap-harian-so') }}
|
||||||
|
@endsection
|
||||||
|
@section('content')
|
||||||
|
<div class="grid">
|
||||||
|
<div class="card border border-agi-100 card-grid min-w-full" data-datatable="false" data-datatable-page-size="10"
|
||||||
|
data-datatable-state-save="false" id="jenis-aset-table">
|
||||||
|
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
||||||
|
<h3 class="card-title">
|
||||||
|
Rekap Harian {{ formatTanggalIndonesia(date('Y-m-d'), false, true) }}
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="scrollable-x-auto">
|
||||||
|
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm"
|
||||||
|
data-datatable-table="true">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th rowspan="2" class="text-center border px-4 py-2">Jenis</th>
|
||||||
|
<th rowspan="2" class="text-center border px-4 py-2">Laporan (Debitur)</th>
|
||||||
|
<th colspan="2" class="text-center border px-4 py-2">Kunjungan</th>
|
||||||
|
<th rowspan="2" class="text-center border px-4 py-2">Pipeline (Proses/Debitur)</th>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th class="text-center border px-4 py-2">Debitur</th>
|
||||||
|
<th class="text-center border px-4 py-2">Lokasi</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
@foreach ($tujuan_penilaian as $jenis)
|
||||||
|
<tr>
|
||||||
|
<td class="text-center border px-4 py-2">{{ $jenis->name }}</td>
|
||||||
|
<td class="text-center border px-4 py-2">{{ 0 }}</td>
|
||||||
|
<td class="text-center border px-4 py-2">{{ 0 }}</td>
|
||||||
|
<td class="text-center border px-4 py-2">{{ 0 }}</td>
|
||||||
|
<td class="text-center border px-4 py-2">{{ 0 }}</td>
|
||||||
|
</tr>
|
||||||
|
@endforeach
|
||||||
|
<tr class="bg-gray-200">
|
||||||
|
<td class="text-center border px-4 py-2 font-bold">Lokasi</td>
|
||||||
|
<td colspan="4" class="text-center border px-4 py-2"></td>
|
||||||
|
</tr>
|
||||||
|
<tr class="bg-gray-300 font-bold">
|
||||||
|
<td class="text-center border px-4 py-2">TOTAL</td>
|
||||||
|
<td class="text-center border px-4 py-2">{{ $totals['laporan_debitur'] ?? '' }}</td>
|
||||||
|
<td class="text-center border px-4 py-2">{{ $totals['kunjungan_debitur'] ?? '' }}</td>
|
||||||
|
<td class="text-center border px-4 py-2">{{ $totals['kunjungan_lokasi'] ?? '' }}</td>
|
||||||
|
<td class="text-center border px-4 py-2">{{ $totals['pipeline'] ?? '' }}</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@endsection
|
||||||
@@ -572,7 +572,7 @@ Breadcrumbs::for('otorisator.show', function (BreadcrumbTrail $trail, $id, $type
|
|||||||
|
|
||||||
|
|
||||||
Breadcrumbs::for('laporan', function (BreadcrumbTrail $trail) {
|
Breadcrumbs::for('laporan', function (BreadcrumbTrail $trail) {
|
||||||
$trail->push('Laporan','');
|
$trail->push('Laporan', '');
|
||||||
});
|
});
|
||||||
|
|
||||||
Breadcrumbs::for('laporan.sederhana.index', function (BreadcrumbTrail $trail) {
|
Breadcrumbs::for('laporan.sederhana.index', function (BreadcrumbTrail $trail) {
|
||||||
@@ -731,11 +731,11 @@ Breadcrumbs::for('laporan-admin-kredit', function ($trail) {
|
|||||||
$trail->push('Laporan Admin Kredit', route('laporan-admin-kredit.index'));
|
$trail->push('Laporan Admin Kredit', route('laporan-admin-kredit.index'));
|
||||||
});
|
});
|
||||||
|
|
||||||
// Laporan Admin Kredit Edit
|
// Laporan Admin Kredit Edit
|
||||||
Breadcrumbs::for('laporan-admin-kredit-edit', function (BreadcrumbTrail $trail, $laporanAdminKredit) {
|
Breadcrumbs::for('laporan-admin-kredit-edit', function (BreadcrumbTrail $trail, $laporanAdminKredit) {
|
||||||
$trail->parent('laporan-admin-kredit');
|
$trail->parent('laporan-admin-kredit');
|
||||||
$trail->push('Edit', route('laporan-admin-kredit.edit', $laporanAdminKredit->id));
|
$trail->push('Edit', route('laporan-admin-kredit.edit', $laporanAdminKredit->id));
|
||||||
});
|
});
|
||||||
|
|
||||||
Breadcrumbs::for('bank-data', function ($trail) {
|
Breadcrumbs::for('bank-data', function ($trail) {
|
||||||
$trail->push('Bank Data', route('bank-data.index'));
|
$trail->push('Bank Data', route('bank-data.index'));
|
||||||
@@ -746,20 +746,45 @@ Breadcrumbs::for('laporan-penilai-jaminan', function ($trail) {
|
|||||||
$trail->push('Laporan Penilai Jaminan', route('laporan-penilai-jaminan.index'));
|
$trail->push('Laporan Penilai Jaminan', route('laporan-penilai-jaminan.index'));
|
||||||
});
|
});
|
||||||
|
|
||||||
Breadcrumbs::for('laporan-permohonan', function ($trail) {
|
Breadcrumbs::for('laporan-permohonan', function ($trail) {
|
||||||
$trail->parent('laporan');
|
$trail->parent('laporan');
|
||||||
$trail->push('Laporan Permohnan', route('laporan-permohonan.index'));
|
$trail->push('Laporan Permohnan', route('laporan-permohonan.index'));
|
||||||
});
|
});
|
||||||
|
|
||||||
Breadcrumbs::for('laporan-penilaian-jaminan', function ($trail) {
|
Breadcrumbs::for('laporan-penilaian-jaminan', function ($trail) {
|
||||||
$trail->parent('laporan');
|
$trail->parent('laporan');
|
||||||
$trail->push('Laporan Penilaian Jaminan', route('laporan-penilaian-jaminan.index'));
|
$trail->push('Laporan Penilaian Jaminan', route('laporan-penilaian-jaminan.index'));
|
||||||
});
|
});
|
||||||
|
|
||||||
Breadcrumbs::for('laporan-hasil-penilaian-jaminan-internal-external', function ($trail) {
|
Breadcrumbs::for('laporan-hasil-penilaian-jaminan-internal-external', function ($trail) {
|
||||||
$trail->parent('laporan');
|
$trail->parent('laporan');
|
||||||
$trail->push('Laporan Hasil Penilaian Jaminan Internal External', route('laporan-hasil-penilaian-jaminan-internal-external.index'));
|
$trail->push('Laporan Hasil Penilaian Jaminan Internal External', route('laporan-hasil-penilaian-jaminan-internal-external.index'));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Breadcrumbs::for('rekap-harian-so', function ($trail) {
|
||||||
|
$trail->push('Rekap Harian');
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
Breadcrumbs::for('laporan-user', function ($trail) {
|
||||||
|
$trail->push('Laporan User Pemohonan', route('laporan-user.index'));
|
||||||
|
});
|
||||||
|
|
||||||
|
Breadcrumbs::for('laporan-monitoring', function ($trail) {
|
||||||
|
$trail->push('Laporan Monitoring', route('laporan-monitoring.index'));
|
||||||
|
});
|
||||||
|
|
||||||
|
Breadcrumbs::for('laporan-monitoring.show', function ($trail) {
|
||||||
|
$trail->parent('laporan-monitoring');
|
||||||
|
$trail->push('Detail');
|
||||||
|
});
|
||||||
|
|
||||||
|
Breadcrumbs::for('laporan-debiture', function ($trail) {
|
||||||
|
$trail->push('Laporan Debiture', route('laporan-debiture.index'));
|
||||||
|
});
|
||||||
|
|
||||||
|
Breadcrumbs::for('laporan-sla-penilai', function ($trail) {
|
||||||
|
$trail->push('Laporan SLA Penilai', route('laporan-sla-penilai.index'));
|
||||||
|
});
|
||||||
// add andy
|
// add andy
|
||||||
require __DIR__ . '/breadcrumbs_registrasi.php';
|
require __DIR__ . '/breadcrumbs_registrasi.php';
|
||||||
|
|||||||
@@ -22,11 +22,11 @@ use Modules\Lpj\Http\Controllers\LampiranDokumenController;
|
|||||||
use Modules\Lpj\Http\Controllers\LaporanAdminKreditController;
|
use Modules\Lpj\Http\Controllers\LaporanAdminKreditController;
|
||||||
use Modules\Lpj\Http\Controllers\LaporanController;
|
use Modules\Lpj\Http\Controllers\LaporanController;
|
||||||
use Modules\Lpj\Http\Controllers\LaporanExternalController;
|
use Modules\Lpj\Http\Controllers\LaporanExternalController;
|
||||||
use Modules\Lpj\Http\Controllers\LaporanHasilPenilaianJaminanInternalExternalController;
|
use Modules\Lpj\Http\Controllers\LaporanHasilPenilaianJaminanInternalExternalController;
|
||||||
use Modules\Lpj\Http\Controllers\LaporanPembatalanController;
|
use Modules\Lpj\Http\Controllers\LaporanPembatalanController;
|
||||||
use Modules\Lpj\Http\Controllers\LaporanPenilaianJaminanController;
|
use Modules\Lpj\Http\Controllers\LaporanPenilaianJaminanController;
|
||||||
use Modules\Lpj\Http\Controllers\LaporanPermohonanController;
|
use Modules\Lpj\Http\Controllers\LaporanPermohonanController;
|
||||||
use Modules\Lpj\Http\Controllers\NilaiPlafondController;
|
use Modules\Lpj\Http\Controllers\NilaiPlafondController;
|
||||||
use Modules\Lpj\Http\Controllers\NocController;
|
use Modules\Lpj\Http\Controllers\NocController;
|
||||||
use Modules\Lpj\Http\Controllers\PembatalanController;
|
use Modules\Lpj\Http\Controllers\PembatalanController;
|
||||||
use Modules\Lpj\Http\Controllers\PemilikJaminanController;
|
use Modules\Lpj\Http\Controllers\PemilikJaminanController;
|
||||||
@@ -44,6 +44,14 @@ use Modules\Lpj\Http\Controllers\TenderController;
|
|||||||
use Modules\Lpj\Http\Controllers\TujuanPenilaianController;
|
use Modules\Lpj\Http\Controllers\TujuanPenilaianController;
|
||||||
use Modules\Lpj\Http\Controllers\TujuanPenilaianKJPPController;
|
use Modules\Lpj\Http\Controllers\TujuanPenilaianKJPPController;
|
||||||
use Modules\Lpj\Http\Controllers\LaporanPenilaiJaminanController;
|
use Modules\Lpj\Http\Controllers\LaporanPenilaiJaminanController;
|
||||||
|
use Modules\Lpj\Http\Controllers\RekapHarianSoController;
|
||||||
|
use Modules\Lpj\Http\Controllers\LaporanBiayaInternalExternalController;
|
||||||
|
use Modules\Lpj\Http\Controllers\LaporanMonitoringSoController;
|
||||||
|
use Modules\Lpj\Http\Controllers\LaporanDebitureController;
|
||||||
|
use Modules\Lpj\Http\Controllers\LaporanUserController;
|
||||||
|
use Modules\Lpj\Http\Controllers\LaporanSLAPenilaiController;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// use Modules\Lpj\Http\Controllers\ActivityController;
|
// use Modules\Lpj\Http\Controllers\ActivityController;
|
||||||
|
|
||||||
@@ -661,7 +669,7 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
|
|
||||||
Route::get('noc/pembayaran', [NocController::class, 'pembayaran'])->name('noc.pembayaran.index');
|
Route::get('noc/pembayaran', [NocController::class, 'pembayaran'])->name('noc.pembayaran.index');
|
||||||
Route::get('noc/penyelesaian', [NocController::class, 'penyelesaian'])->name('noc.penyelesaian.index');
|
Route::get('noc/penyelesaian', [NocController::class, 'penyelesaian'])->name('noc.penyelesaian.index');
|
||||||
Route::post('noc/penyelesaian',[NocController::class, 'penyelesaian'])->name('noc.store.penyelesaian');
|
Route::post('noc/penyelesaian', [NocController::class, 'penyelesaian'])->name('noc.store.penyelesaian');
|
||||||
|
|
||||||
Route::resource('noc', NocController::class);
|
Route::resource('noc', NocController::class);
|
||||||
|
|
||||||
@@ -685,6 +693,7 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
Route::put('{id}', [LaporanAdminKreditController::class,'update'])->name('update');
|
Route::put('{id}', [LaporanAdminKreditController::class,'update'])->name('update');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
Route::name('bank-data.')->prefix('bank-data')->group(function () {
|
Route::name('bank-data.')->prefix('bank-data')->group(function () {
|
||||||
Route::get('datatables', [BankDataController::class, 'dataForDatatables'])->name('datatables');
|
Route::get('datatables', [BankDataController::class, 'dataForDatatables'])->name('datatables');
|
||||||
});
|
});
|
||||||
@@ -697,7 +706,7 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
Route::get('export', [LaporanPenilaiJaminanController::class, 'export'])->name('export');
|
Route::get('export', [LaporanPenilaiJaminanController::class, 'export'])->name('export');
|
||||||
});
|
});
|
||||||
|
|
||||||
Route::prefix('laporan-permohonan')->name('laporan-permohonan.')->group(function() {
|
Route::prefix('laporan-permohonan')->name('laporan-permohonan.')->group(function () {
|
||||||
Route::get('datatables', [LaporanPermohonanController::class, 'dataForDatatables'])->name('data');
|
Route::get('datatables', [LaporanPermohonanController::class, 'dataForDatatables'])->name('data');
|
||||||
Route::get('export', [LaporanPermohonanController::class, 'export'])->name('export');
|
Route::get('export', [LaporanPermohonanController::class, 'export'])->name('export');
|
||||||
Route::get('/', [LaporanPermohonanController::class, 'index'])->name('index');
|
Route::get('/', [LaporanPermohonanController::class, 'index'])->name('index');
|
||||||
@@ -710,18 +719,53 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
Route::get('/export', [LaporanPembatalanController::class, 'export'])->name('export');
|
Route::get('/export', [LaporanPembatalanController::class, 'export'])->name('export');
|
||||||
});
|
});
|
||||||
|
|
||||||
Route::prefix('laporan-penilaian-jaminan')->name('laporan-penilaian-jaminan.')->group(function() {
|
Route::prefix('laporan-penilaian-jaminan')->name('laporan-penilaian-jaminan.')->group(function () {
|
||||||
Route::get('datatables', [LaporanPenilaianJaminanController::class, 'dataForDatatables'])->name('data');
|
Route::get('datatables', [LaporanPenilaianJaminanController::class, 'dataForDatatables'])->name('data');
|
||||||
Route::get('export', [LaporanPenilaianJaminanController::class, 'export'])->name('export');
|
Route::get('export', [LaporanPenilaianJaminanController::class, 'export'])->name('export');
|
||||||
Route::get('/', [LaporanPenilaianJaminanController::class, 'index'])->name('index');
|
Route::get('/', [LaporanPenilaianJaminanController::class, 'index'])->name('index');
|
||||||
});
|
});
|
||||||
|
|
||||||
Route::prefix('laporan-hasil-penilaian-jaminan-internal-external')->name('laporan-hasil-penilaian-jaminan-internal-external.')->group(function() {
|
Route::prefix('laporan-hasil-penilaian-jaminan-internal-external')->name('laporan-hasil-penilaian-jaminan-internal-external.')->group(function () {
|
||||||
Route::get('datatables', [LaporanHasilPenilaianJaminanInternalExternalController::class, 'dataForDatatables'])->name('data');
|
Route::get('datatables', [LaporanHasilPenilaianJaminanInternalExternalController::class, 'dataForDatatables'])->name('data');
|
||||||
Route::get('export', [LaporanHasilPenilaianJaminanInternalExternalController::class, 'export'])->name('export');
|
Route::get('export', [LaporanHasilPenilaianJaminanInternalExternalController::class, 'export'])->name('export');
|
||||||
Route::get('/', [LaporanHasilPenilaianJaminanInternalExternalController::class, 'index'])->name('index');
|
Route::get('/', [LaporanHasilPenilaianJaminanInternalExternalController::class, 'index'])->name('index');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// rekap harian so
|
||||||
|
Route::resource('rekap-harian-so', RekapHarianSoController::class);
|
||||||
|
|
||||||
|
// laporan biaya
|
||||||
|
Route::prefix('laporan-biaya')->name('laporan-biaya.')->group(function () {
|
||||||
|
Route::get('internal', [LaporanBiayaInternalExternalController::class, 'showLaporanBiayaInternal'])->name('internal.index');
|
||||||
|
Route::get('external', [LaporanBiayaInternalExternalController::class, 'showLaporanBiayaExternal'])->name('external.index');
|
||||||
|
});
|
||||||
|
|
||||||
|
// laporan user
|
||||||
|
Route::prefix('laporan-user')->name('laporan-user.')->group(function () {
|
||||||
|
Route::get('/', [LaporanUserController::class, 'index'])->name('index');
|
||||||
|
Route::get('api/user-pemohon', [LaporanUserController::class, 'searchUserPemohon'])->name('api.user-pemohon');
|
||||||
|
Route::get('datatables', [LaporanUserController::class, 'dataTableForUserPemohon'])->name('datatables');
|
||||||
|
});
|
||||||
|
|
||||||
|
// laporan monitoring
|
||||||
|
Route::prefix('laporan-monitoring')->name('laporan-monitoring.')->group(function () {
|
||||||
|
Route::get('/', [LaporanMonitoringSoController::class, 'index'])->name('index');
|
||||||
|
Route::get('/{id}/detail', [LaporanMonitoringSoController::class, 'show'])->name('show');
|
||||||
|
Route::get('datatables/{id}', [LaporanMonitoringSoController::class, 'dataForDatatablePenilai'])->name('datatables');
|
||||||
|
});
|
||||||
|
|
||||||
|
// laporan debiture
|
||||||
|
Route::prefix('laporan-debiture')->name('laporan-debiture.')->group(function () {
|
||||||
|
Route::get('/', [LaporanDebitureController::class, 'index'])->name('index');
|
||||||
|
Route::get('datatables', [LaporanDebitureController::class, 'dataTableForDebiture'])->name('datatables');
|
||||||
|
});
|
||||||
|
|
||||||
|
// laporan sla
|
||||||
|
Route::prefix('laporan-sla-penilai')->name('laporan-sla-penilai.')->group(function () {
|
||||||
|
Route::get('/', [LaporanSLAPenilaiController::class, 'index'])->name('index');
|
||||||
|
Route::get('datatables', [LaporanSLAPenilaiController::class, 'dataForDatatableSLaPenilai'])->name('datatables');
|
||||||
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
require __DIR__ . '/registrasi.php';
|
require __DIR__ . '/registrasi.php';
|
||||||
|
|||||||
Reference in New Issue
Block a user