Compare commits
12 Commits
02d2e42621
...
be41a815f7
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
be41a815f7 | ||
|
|
c459d1be70 | ||
|
|
142257d18d | ||
|
|
32eab5f089 | ||
|
|
84933206ee | ||
|
|
1338085481 | ||
|
|
3f57d361f9 | ||
|
|
027c698a11 | ||
|
|
05f87f4767 | ||
|
|
6bb13dbcaf | ||
|
|
e79b8c6449 | ||
|
|
28513100f4 |
232
app/Exports/LaporanUserLimitExport.php
Normal file
232
app/Exports/LaporanUserLimitExport.php
Normal file
@@ -0,0 +1,232 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Exports;
|
||||||
|
|
||||||
|
use Maatwebsite\Excel\Concerns\FromCollection;
|
||||||
|
use Maatwebsite\Excel\Concerns\WithHeadings;
|
||||||
|
use Maatwebsite\Excel\Concerns\WithMapping;
|
||||||
|
use Maatwebsite\Excel\Concerns\WithTitle;
|
||||||
|
use Maatwebsite\Excel\Concerns\WithCustomStartCell;
|
||||||
|
use Maatwebsite\Excel\Concerns\WithEvents;
|
||||||
|
use Maatwebsite\Excel\Events\AfterSheet;
|
||||||
|
use Modules\Lpj\Models\Permohonan;
|
||||||
|
use Modules\Lpj\Models\Branch;
|
||||||
|
use Illuminate\Support\Facades\Auth;
|
||||||
|
use Carbon\Carbon;
|
||||||
|
use Illuminate\Support\Facades\DB;
|
||||||
|
|
||||||
|
class LaporanUserLimitExport implements FromCollection, WithHeadings, WithMapping, WithTitle, WithCustomStartCell, WithEvents
|
||||||
|
{
|
||||||
|
protected $request;
|
||||||
|
|
||||||
|
public function __construct($request)
|
||||||
|
{
|
||||||
|
$this->request = $request;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function collection()
|
||||||
|
{
|
||||||
|
$query = Permohonan::query();
|
||||||
|
$query = $query->where('status', 'done');
|
||||||
|
|
||||||
|
// Apply date range filter if provided
|
||||||
|
if ($this->request->has('start_date') || $this->request->has('end_date')) {
|
||||||
|
$startDate = $this->request->start_date ?? '1900-01-01';
|
||||||
|
$endDate = $this->request->end_date ?? now()->toDateString();
|
||||||
|
|
||||||
|
$query->where(function ($q) use ($startDate, $endDate) {
|
||||||
|
|
||||||
|
$q->whereHas('penilaian', function ($q2) use ($startDate, $endDate) {
|
||||||
|
$q2->whereBetween('tanggal_kunjungan', [$startDate, $endDate]);
|
||||||
|
});
|
||||||
|
|
||||||
|
// OR check if has penawaran with date in range
|
||||||
|
$q->orWhereHas('penawaran', function ($q3) use ($startDate, $endDate) {
|
||||||
|
$q3->whereBetween('tanggal_penilaian_sebelumnya', [$startDate, $endDate]);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Apply branch filter if provided
|
||||||
|
if ($this->request->has('branch_id') && !empty($this->request->branch_id)) {
|
||||||
|
$query->where('branch_id', $this->request->branch_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->request->has('penilai_id') && !empty($this->request->penilai_id)) {
|
||||||
|
$request = $this->request; // Store in a local variable
|
||||||
|
$query->whereHas('penilaian._user_penilai.userPenilaiTeam', function ($q) use ($request) {
|
||||||
|
$q->where('user_id', $request->penilai_id);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Apply search filter if provided
|
||||||
|
if ($this->request->has('search') && !empty($this->request->search)) {
|
||||||
|
$search = $this->request->search;
|
||||||
|
$query->where(function ($q) use ($search) {
|
||||||
|
$q->where('nomor_registrasi', 'LIKE', '%' . $search . '%');
|
||||||
|
$q->orWhere('tanggal_permohonan', 'LIKE', '%' . $search . '%');
|
||||||
|
$q->orWhereRelation('user', 'name', 'LIKE', '%' . $search . '%');
|
||||||
|
$q->orWhereRelation('tujuanPenilaian', 'name', 'LIKE', '%' . $search . '%');
|
||||||
|
$q->orWhereRelation('debiture', DB::raw('LOWER(name)'), 'LIKE', '%' . strtolower($search) . '%');
|
||||||
|
|
||||||
|
$q->orWhereRelation('branch', 'name', 'LIKE', '%' . $search . '%');
|
||||||
|
$q->orWhereRelation('jenisFasilitasKredit', 'name', 'LIKE', '%' . $search . '%');
|
||||||
|
$q->orWhereRelation('jenisPenilaian', 'name', 'LIKE', '%' . $search . '%');
|
||||||
|
$q->orWhere('status', 'LIKE', '%' . $search . '%');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Default ordering
|
||||||
|
$query->orderBy('nomor_registrasi', 'asc');
|
||||||
|
|
||||||
|
return $query->get();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected $rowNumber = 0;
|
||||||
|
|
||||||
|
public function map($permohonan): array
|
||||||
|
{
|
||||||
|
$this->rowNumber++;
|
||||||
|
$npw = 0;
|
||||||
|
|
||||||
|
if (isset($permohonan->penilai->lpj)) {
|
||||||
|
$lpj = json_decode($permohonan->penilai->lpj, true);
|
||||||
|
$npw = str_replace('.', '', $lpj['total_nilai_pasar_wajar'] ?? 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
$this->rowNumber,
|
||||||
|
$permohonan->nomor_registrasi,
|
||||||
|
$permohonan->debiture->branch->name ?? '',
|
||||||
|
$permohonan->debiture->name ?? '',
|
||||||
|
$permohonan->user->name ?? $permohonan->mig_nama_ao ?? '',
|
||||||
|
$permohonan->tanggal_permohonan ?? '',
|
||||||
|
$permohonan->penilaian->_user_penilai->userPenilaiTeam->name ?? '',
|
||||||
|
$permohonan->penilaian && $permohonan->penilaian->tanggal_kunjungan
|
||||||
|
? formatTanggalIndonesia($permohonan->penilaian->tanggal_kunjungan)
|
||||||
|
: '',
|
||||||
|
formatRupiah($npw, 2),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function headings(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'No',
|
||||||
|
'Nomor Registrasi',
|
||||||
|
'Cabang',
|
||||||
|
'Nama Debitur',
|
||||||
|
'Pemohon',
|
||||||
|
'Tanggal Permohonan',
|
||||||
|
'Nama Penilai',
|
||||||
|
'Tanggal Laporan',
|
||||||
|
'Nilai Pasar Wajar',
|
||||||
|
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function title(): string
|
||||||
|
{
|
||||||
|
return 'Laporan User Limit';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function startCell(): string
|
||||||
|
{
|
||||||
|
return 'A7';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function registerEvents(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
AfterSheet::class => function (AfterSheet $event) {
|
||||||
|
// Get the sheet
|
||||||
|
$sheet = $event->sheet->getDelegate();
|
||||||
|
|
||||||
|
// Set the title
|
||||||
|
$sheet->setCellValue('A1', 'LAPORAN PENILAIAN JAMINAN');
|
||||||
|
$sheet->getStyle('A1')->getFont()->setBold(true)->setSize(16);
|
||||||
|
|
||||||
|
// Merge cells for title
|
||||||
|
$sheet->mergeCells('A1:AH1');
|
||||||
|
$sheet->getStyle('A1')->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER);
|
||||||
|
|
||||||
|
// Set the branch information if filtered
|
||||||
|
$branchInfo = '';
|
||||||
|
if ($this->request->has('branch_id') && !empty($this->request->branch_id)) {
|
||||||
|
$branch = Branch::find($this->request->branch_id);
|
||||||
|
if ($branch) {
|
||||||
|
$branchInfo = 'Cabang: ' . $branch->name;
|
||||||
|
$sheet->setCellValue('A2', $branchInfo);
|
||||||
|
$sheet->mergeCells('A2:AH2');
|
||||||
|
$sheet->getStyle('A2')->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER);
|
||||||
|
$sheet->getStyle('A2')->getFont()->setBold(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set the period
|
||||||
|
$startDate = $this->request->start_date ?? '';
|
||||||
|
$endDate = $this->request->end_date ?? '';
|
||||||
|
|
||||||
|
$rowIndex = $branchInfo ? 3 : 2;
|
||||||
|
|
||||||
|
if ($startDate && $endDate) {
|
||||||
|
$startDateFormatted = Carbon::parse($startDate)->format('d F Y');
|
||||||
|
$endDateFormatted = Carbon::parse($endDate)->format('d F Y');
|
||||||
|
$sheet->setCellValue('A' . $rowIndex, 'Periode: ' . $startDateFormatted . ' - ' . $endDateFormatted);
|
||||||
|
} else {
|
||||||
|
$sheet->setCellValue('A' . $rowIndex, 'Periode: Semua Data');
|
||||||
|
}
|
||||||
|
$sheet->mergeCells('A' . $rowIndex . ':AH' . $rowIndex);
|
||||||
|
$sheet->getStyle('A' . $rowIndex)->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER);
|
||||||
|
|
||||||
|
// Set the date of export
|
||||||
|
$rowIndex++;
|
||||||
|
$sheet->setCellValue('A' . $rowIndex, 'Tanggal Export: ' . Carbon::now()->format('d F Y H:i:s'));
|
||||||
|
|
||||||
|
// Set the user who exported
|
||||||
|
$rowIndex++;
|
||||||
|
$userName = Auth::user() ? Auth::user()->name : 'System';
|
||||||
|
$sheet->setCellValue('A' . $rowIndex, 'Diexport oleh: ' . $userName);
|
||||||
|
|
||||||
|
// Add a blank line
|
||||||
|
$rowIndex++;
|
||||||
|
$sheet->setCellValue('A' . $rowIndex, '');
|
||||||
|
|
||||||
|
// Style the header row
|
||||||
|
$headerRange = 'A7:' . $sheet->getHighestColumn() . '7';
|
||||||
|
$sheet->getStyle($headerRange)->getFont()->setBold(true);
|
||||||
|
$sheet->getStyle($headerRange)->getFill()
|
||||||
|
->setFillType(\PhpOffice\PhpSpreadsheet\Style\Fill::FILL_SOLID)
|
||||||
|
->getStartColor()->setARGB('FFCCCCCC');
|
||||||
|
|
||||||
|
// Auto-size columns - fixed to handle columns beyond Z
|
||||||
|
$highestColumn = $sheet->getHighestColumn();
|
||||||
|
$highestColumnIndex = \PhpOffice\PhpSpreadsheet\Cell\Coordinate::columnIndexFromString($highestColumn);
|
||||||
|
|
||||||
|
for ($i = 1; $i <= $highestColumnIndex; $i++) {
|
||||||
|
$currentColumn = \PhpOffice\PhpSpreadsheet\Cell\Coordinate::stringFromColumnIndex($i);
|
||||||
|
$sheet->getColumnDimension($currentColumn)->setAutoSize(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add borders to all cells with data
|
||||||
|
$dataRange = 'A7:' . $sheet->getHighestColumn() . $sheet->getHighestRow();
|
||||||
|
$sheet->getStyle($dataRange)->getBorders()->getAllBorders()->setBorderStyle(\PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN);
|
||||||
|
|
||||||
|
// Center align the header row
|
||||||
|
$sheet->getStyle($headerRange)->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER);
|
||||||
|
|
||||||
|
// Set text wrap for header cells
|
||||||
|
$sheet->getStyle($headerRange)->getAlignment()->setWrapText(true);
|
||||||
|
},
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -15,6 +15,8 @@
|
|||||||
use Modules\Lpj\Models\Penilaian;
|
use Modules\Lpj\Models\Penilaian;
|
||||||
use Modules\Lpj\Models\TeamsUsers;
|
use Modules\Lpj\Models\TeamsUsers;
|
||||||
use Modules\Usermanagement\Models\User;
|
use Modules\Usermanagement\Models\User;
|
||||||
|
use Illuminate\Support\Facades\File;
|
||||||
|
use Illuminate\Support\Facades\Storage;
|
||||||
|
|
||||||
function formatTanggalIndonesia($date, $time = false)
|
function formatTanggalIndonesia($date, $time = false)
|
||||||
{
|
{
|
||||||
@@ -557,3 +559,37 @@ function parsePembandingMigration($keterangan) {
|
|||||||
|
|
||||||
return implode("\n", $cleaned);
|
return implode("\n", $cleaned);
|
||||||
}
|
}
|
||||||
|
/**
|
||||||
|
* get full path to internal storage file or external storage file
|
||||||
|
*
|
||||||
|
* @param string $path
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
|
||||||
|
function getFilePath($path)
|
||||||
|
{
|
||||||
|
// define base path external storage (use .env) example: 'F:\path\to\storage' in windows
|
||||||
|
$externalBase = env('EXTERNAL_STORAGE_BASE_PATH', 'F:LPJ/lpj/LPJ Gambar/001/');
|
||||||
|
|
||||||
|
$segments = explode('/', $path);
|
||||||
|
|
||||||
|
if(strtoupper($segments[0]) === 'SURVEYOR'){
|
||||||
|
$year = $segments[1];
|
||||||
|
$month = ucfirst(strtolower($segments[2]));
|
||||||
|
$date = $segments[3];
|
||||||
|
$code = $segments[4];
|
||||||
|
$file = $segments[5] ?? '';
|
||||||
|
|
||||||
|
$extenalFullpath = $externalBase . $year . '/' . $month . '/' . $date . '/' . $code . '/' . $file;
|
||||||
|
|
||||||
|
if(File::exists($extenalFullpath)){
|
||||||
|
return $extenalFullpath;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// if not found in external storage, try to find in internal storage
|
||||||
|
if (Storage::exists($path)) {
|
||||||
|
return Storage::url('app/' . $path);
|
||||||
|
}
|
||||||
|
return $path;
|
||||||
|
}
|
||||||
|
|||||||
@@ -4,6 +4,8 @@ namespace Modules\Lpj\Http\Controllers;
|
|||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
use Maatwebsite\Excel\Facades\Excel;
|
||||||
|
use Modules\Lpj\Exports\LaporanUserLimitExport;
|
||||||
use Modules\Lpj\Services\LaporanUserService;
|
use Modules\Lpj\Services\LaporanUserService;
|
||||||
|
|
||||||
class LaporanUserController extends Controller
|
class LaporanUserController extends Controller
|
||||||
@@ -38,4 +40,12 @@ class LaporanUserController extends Controller
|
|||||||
return $this->laporanUserService->dataForDatatables($request);
|
return $this->laporanUserService->dataForDatatables($request);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function export(Request $request)
|
||||||
|
{
|
||||||
|
$startDate = $request->start_date;
|
||||||
|
$endDate = $request->end_date;
|
||||||
|
// name of the file
|
||||||
|
$fileName = 'laporan_user_limit' . $startDate . '_' . $endDate . '.xlsx';
|
||||||
|
return Excel::download(new LaporanUserLimitExport($request), $fileName);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
*/
|
*/
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
return redirect()->route('noc.pembayaran');
|
return redirect()->route('noc.pembayaran.index');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function pembayaran()
|
public function pembayaran()
|
||||||
@@ -80,7 +80,7 @@
|
|||||||
}
|
}
|
||||||
$noc->save();
|
$noc->save();
|
||||||
|
|
||||||
// Update the status of the related permohonan to 'spk'
|
/* Update the status of the related permohonan to 'spk'
|
||||||
$permohonan = Permohonan::find(request()->get('permohonan_id'));
|
$permohonan = Permohonan::find(request()->get('permohonan_id'));
|
||||||
if ($permohonan) {
|
if ($permohonan) {
|
||||||
$permohonan->status_bayar = request()->get('status_pembayar');
|
$permohonan->status_bayar = request()->get('status_pembayar');
|
||||||
@@ -99,7 +99,7 @@
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
// andy add, update status penawaran.status='spk'
|
// andy add, update status penawaran.status='spk'
|
||||||
}
|
}*/
|
||||||
|
|
||||||
return redirect()
|
return redirect()
|
||||||
->route('noc.index')->with('success', 'NOC berhasil disimpan.');
|
->route('noc.index')->with('success', 'NOC berhasil disimpan.');
|
||||||
@@ -175,9 +175,7 @@
|
|||||||
/**
|
/**
|
||||||
* Display the specified resource.
|
* Display the specified resource.
|
||||||
*/
|
*/
|
||||||
public function show(Request $request) {
|
public function show(Noc $noc) {
|
||||||
$noc = Noc::find($request->get('id'));
|
|
||||||
|
|
||||||
return view('lpj::noc.memo', compact('noc'));
|
return view('lpj::noc.memo', compact('noc'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -80,14 +80,10 @@ class DaftarPustakaService
|
|||||||
$today = now();
|
$today = now();
|
||||||
$folderPath = 'daftar_pustaka/' . $today->format('Y/m/d');
|
$folderPath = 'daftar_pustaka/' . $today->format('Y/m/d');
|
||||||
|
|
||||||
if (!file_exists(public_path($folderPath))) {
|
|
||||||
mkdir(public_path($folderPath), 0755, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
$fileName = $file->getClientOriginalName();
|
$fileName = $file->getClientOriginalName();
|
||||||
$file->move(public_path($folderPath), $fileName);
|
$filePath = $file->storeAs($folderPath, $fileName, 'public');
|
||||||
|
|
||||||
return $folderPath . '/' . $fileName;
|
return $filePath;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
21
app/Services/LaporanBiayaService.php
Normal file
21
app/Services/LaporanBiayaService.php
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Services;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Modules\Lpj\Models\Permohonan;
|
||||||
|
|
||||||
|
class LaporanBiayaService
|
||||||
|
{
|
||||||
|
public function buildDataTableQuery(array $data){
|
||||||
|
$query = Permohonan::with([
|
||||||
|
'noc'
|
||||||
|
]);
|
||||||
|
|
||||||
|
if($data['search']){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return $query;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -5,6 +5,7 @@ namespace Modules\Lpj\Services;
|
|||||||
use Modules\Lpj\Models\Permohonan;
|
use Modules\Lpj\Models\Permohonan;
|
||||||
use Modules\Lpj\Models\Penilaian;
|
use Modules\Lpj\Models\Penilaian;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
use Carbon\Carbon;
|
||||||
|
|
||||||
class LaporanSLAPenilaiService
|
class LaporanSLAPenilaiService
|
||||||
{
|
{
|
||||||
@@ -70,27 +71,15 @@ class LaporanSLAPenilaiService
|
|||||||
$filteredRecords = $query->count();
|
$filteredRecords = $query->count();
|
||||||
|
|
||||||
// Get the data for the current page
|
// Get the data for the current page
|
||||||
$data = $query->with(['debiture.branch'])->get();
|
$data = $query->with(['documents','debiture.branch'])->get();
|
||||||
|
|
||||||
$data = $data->map(function ($permohonan) {
|
$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;
|
$tgl_kunjungan = $permohonan->penilaian?->tanggal_kunjungan;
|
||||||
$luas_bangunan = $lpj['luas_bangunan'] ?? 0;
|
$tgl_otorisator = $permohonan->approval_dd_at ?? $permohonan->approval_eo_at ?? $permohonan->approval_so_at;
|
||||||
// Calculate nilai_tanah dynamically by looking for all keys that start with 'nilai_tanah_'
|
$jangkaWaktu = $this->hitungTotalJangkaWaktuSla($tgl_kunjungan, $tgl_otorisator);
|
||||||
$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 [
|
return [
|
||||||
'id' => $permohonan->id,
|
'id' => $permohonan->id,
|
||||||
@@ -100,11 +89,12 @@ class LaporanSLAPenilaiService
|
|||||||
'name' => $permohonan->debiture?->name,
|
'name' => $permohonan->debiture?->name,
|
||||||
'pemohon' => $permohonan->creator?->name,
|
'pemohon' => $permohonan->creator?->name,
|
||||||
'tujuan_penilaian' => $permohonan->tujuanPenilaian?->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_laporan' => $permohonan->approval_dd_at ?? $permohonan->approval_eo_at ?? '',
|
||||||
'tanggal_review' => $permohonan->penilaian?->tanggal_kunjungan ?? '',
|
'tanggal_approval' => $permohonan->approval_dd_at ?? $permohonan->approval_eo_at ?? '',
|
||||||
|
'tanggal_kunjungan' => $permohonan->penilaian?->tanggal_kunjungan ?? '',
|
||||||
'nama_penilai' => $permohonan->penilaian?->_user_penilai?->userPenilaiTeam?->name,
|
'nama_penilai' => $permohonan->penilaian?->_user_penilai?->userPenilaiTeam?->name,
|
||||||
|
'jangka_waktu' => $jangkaWaktu,
|
||||||
|
'keterangan' => $permohonan->keterangan
|
||||||
];
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -125,4 +115,9 @@ class LaporanSLAPenilaiService
|
|||||||
'data' => $data,
|
'data' => $data,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function hitungTotalJangkaWaktuSla($tgl_kunjungan,$tgl_otorisator){
|
||||||
|
$countHariKerja = hitungHariKerja($tgl_kunjungan, $tgl_otorisator);
|
||||||
|
return $countHariKerja;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,10 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace Modules\Lpj\Services;
|
namespace Modules\Lpj\Services;
|
||||||
|
|
||||||
use Modules\Lpj\Models\Permohonan;
|
use Modules\Lpj\Models\Permohonan;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
use Modules\Usermanagement\Models\User;
|
||||||
|
|
||||||
class LaporanUserService
|
class LaporanUserService
|
||||||
{
|
{
|
||||||
@@ -25,36 +27,15 @@ class LaporanUserService
|
|||||||
{
|
{
|
||||||
|
|
||||||
// Retrieve data from the database
|
// Retrieve data from the database
|
||||||
$query = Permohonan::query();
|
$query = User::query();
|
||||||
$query = $query->where('status', 'done');
|
|
||||||
|
|
||||||
// Apply search filter if provided
|
// Apply search filter if provided
|
||||||
if ($request->has('search') && !empty($request->get('search'))) {
|
if ($request->has('search') && !empty($request->get('search'))) {
|
||||||
$search = json_decode($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)) {
|
if (isset($search->search)) {
|
||||||
|
|
||||||
$query->where(function ($q) use ($search) {
|
$query->where(function ($q) use ($search) {
|
||||||
$q->where('nomor_registrasi', 'LIKE', '%' . $search->search . '%');
|
$q->whereRaw('LOWER(name) LIKE ?', ['%' . strtolower($search) . '%']);
|
||||||
$q->orWhere('tanggal_permohonan', 'LIKE', '%' . $search->search . '%');
|
$q->where('nik', '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 . '%');
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -82,99 +63,16 @@ class LaporanUserService
|
|||||||
$filteredRecords = $query->count();
|
$filteredRecords = $query->count();
|
||||||
|
|
||||||
// Get the data for the current page
|
// Get the data for the current page
|
||||||
$data = $query->with(['debiture.branch'])->get();
|
$data = $query->with(['branch', 'roles'])->get();
|
||||||
|
|
||||||
$data = $data->map(function ($permohonan) {
|
$data = $data->map(function ($user) {
|
||||||
$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 [
|
return [
|
||||||
'id' => $permohonan->id,
|
'id' => $user->id,
|
||||||
'nomor_registrasi' => $permohonan->nomor_registrasi,
|
'nik' => $user->nik,
|
||||||
'jenis_penilaian' => $permohonan->jenisPenilaian?->name,
|
'name' => $user->name,
|
||||||
'tujuan_penilaian' => $permohonan->tujuanPenilaian?->name,
|
'level' => $user->roles->pluck('name')->implode(', '),
|
||||||
'jenis_fasilitas_kredit' => $permohonan->jenisFasilitasKredit?->name,
|
'approval_limit' => 0,
|
||||||
'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 ?? '',
|
|
||||||
];
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -268,7 +268,7 @@
|
|||||||
|
|
||||||
return `
|
return `
|
||||||
<div class="flex flex-nowrap justify-center">
|
<div class="flex flex-nowrap justify-center">
|
||||||
<a class="btn btn-sm btn-icon btn-clear btn-warning" href="activity/${data.id}/show" title="Lihat Detail">
|
<a class="btn btn-sm btn-icon ${status === 'freeze' ? 'btn-light' : 'btn-warning btn-clear'}" href="activity/${data.id}/show" title="Lihat Detail">
|
||||||
<i class="ki-outline ki-eye"></i>
|
<i class="ki-outline ki-eye"></i>
|
||||||
</a>
|
</a>
|
||||||
${
|
${
|
||||||
@@ -290,8 +290,38 @@
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
let dataTable = new KTDataTable(element, dataTableOptions);
|
let dataTable = new KTDataTable(element, dataTableOptions);
|
||||||
|
|
||||||
|
function highlightFreezeRows() {
|
||||||
|
const table = document.querySelector('#permohonan-table table[data-datatable-table="true"]');
|
||||||
|
if (!table) return;
|
||||||
|
|
||||||
|
const rows = table.querySelectorAll('tbody tr');
|
||||||
|
|
||||||
|
rows.forEach(row => {
|
||||||
|
const statusCell = row.cells[7];
|
||||||
|
if (!statusCell) return;
|
||||||
|
|
||||||
|
const statusText = statusCell.textContent.trim().toLowerCase();
|
||||||
|
|
||||||
|
if (statusText === 'freeze') {
|
||||||
|
row.classList.add('bg-red-400', 'text-white');
|
||||||
|
} else {
|
||||||
|
row.classList.remove('bg-red-400', 'text-white');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Polling setiap 1 detik untuk sementara
|
||||||
|
setInterval(() => {
|
||||||
|
highlightFreezeRows();
|
||||||
|
}, 500);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
searchInput.addEventListener('input', function() {
|
searchInput.addEventListener('input', function() {
|
||||||
const searchValue = this.value.trim();
|
const searchValue = this.value.trim();
|
||||||
dataTable.search(searchValue, true);
|
dataTable.search(searchValue, true);
|
||||||
|
|||||||
@@ -13,9 +13,12 @@
|
|||||||
<button id="tab-hasil" class="btn btn-sm btn-light">Hasil Inspeksi</button>
|
<button id="tab-hasil" class="btn btn-sm btn-light">Hasil Inspeksi</button>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex items-wrap gap-2.5">
|
<div class="flex items-wrap gap-2.5">
|
||||||
<a href="{{ $back ?? route()->previous()}}" class="btn btn-xs btn-info"><i
|
{{-- <a href="{{ $back ?? route()->previous()}}" class="btn btn-xs btn-info"><i
|
||||||
class="ki-filled ki-exit-left"></i>
|
class="ki-filled ki-exit-left"></i>
|
||||||
Back</a>
|
Back</a> --}}
|
||||||
|
<a id="back-button" class="btn btn-xs btn-info">
|
||||||
|
<i class="ki-filled ki-exit-left"></i> Back
|
||||||
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -87,6 +90,18 @@
|
|||||||
hasilContent.classList.remove('hidden-tab');
|
hasilContent.classList.remove('hidden-tab');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
document.getElementById('back-button').addEventListener('click', function(e) {
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
console.log('Back button clicked', window.history.length);
|
||||||
|
if (window.history.length > 1) {
|
||||||
|
window.history.back();
|
||||||
|
} else {
|
||||||
|
window.location.href = "{{ $back ?? route()->previous()}}";
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
|||||||
@@ -57,7 +57,7 @@
|
|||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
{{-- ambil nama file pathnya hilangkan --}}
|
{{-- ambil nama file pathnya hilangkan --}}
|
||||||
<a href="{{ asset($daftarPustaka->attachment) }}" class="badge badge-outline badge-md badge-info">{{ basename($daftarPustaka->attachment) }}
|
<a href="{{ asset('storage/' .$daftarPustaka->attachment) }}" class="badge badge-outline badge-md badge-info">{{ basename($daftarPustaka->attachment) }}
|
||||||
<i class="ki-filled ki-cloud-download"></i>
|
<i class="ki-filled ki-cloud-download"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -5,6 +5,15 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@section('content')
|
@section('content')
|
||||||
|
<style>
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
#previewContent {
|
||||||
|
height: 400px;
|
||||||
|
overflow: auto;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
</style>
|
||||||
|
|
||||||
<div class="flex flex-col items-stretch gap-7">
|
<div class="flex flex-col items-stretch gap-7">
|
||||||
<div class="flex items-center gap-3 w-full">
|
<div class="flex items-center gap-3 w-full">
|
||||||
@@ -66,10 +75,12 @@
|
|||||||
@if (isset($daftar_pustaka))
|
@if (isset($daftar_pustaka))
|
||||||
@foreach ($daftar_pustaka as $item)
|
@foreach ($daftar_pustaka as $item)
|
||||||
<div class="card border shadow-none ">
|
<div class="card border shadow-none ">
|
||||||
<a class="show-pustaka h-[300px] w-full block" href="{{ route('daftar-pustaka.show', $item->id) }}"
|
<a class="show-pustaka h-[300px] bg-gray-200 w-full block" href="{{ route('daftar-pustaka.show', $item->id) }}"
|
||||||
data-url="{{ $item->attachment }}">
|
data-url="{{ $item->attachment }}">
|
||||||
<div class="p-4 h-full w-full flex items-center justify-center overflow-hidden">
|
<div class="p-4 h-full w-full flex items-center justify-center overflow-hidden">
|
||||||
<div class="preview-content h-full w-full"></div>
|
<div class=" text-red-500 flex items-center justify-center rounded">
|
||||||
|
<i class="ki-filled ki-document text-3xl"></i>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
@@ -84,18 +95,18 @@
|
|||||||
</p>
|
</p>
|
||||||
</a>
|
</a>
|
||||||
<div class="flex justify-between items-center gap-2.5 mt-2">
|
<div class="flex justify-between items-center gap-2.5 mt-2">
|
||||||
<p class="badge rounded-full badge-sm badge-outline badge-success text-xs text-gray-700">
|
<p class="badge rounded-full badge-xs badge-outline badge-success text-xs text-gray-700">
|
||||||
# {{ $item->category->name }}</p>
|
# {{ $item->category->name }}</p>
|
||||||
|
|
||||||
@auth
|
@auth
|
||||||
@if (auth()->user()->hasRole(['administrator', 'admin']))
|
@if (auth()->user()->hasRole(['administrator', 'admin']))
|
||||||
<div>
|
<div>
|
||||||
<a class="btn btn-sm btn-danger" onclick="deleteData({{ $item->id }})">
|
<a class="btn btn-xs btn-danger" onclick="deleteData({{ $item->id }})">
|
||||||
<i class="ki-filled ki-trash">
|
<i class="ki-filled ki-trash">
|
||||||
</i>
|
</i>
|
||||||
Hapus
|
Hapus
|
||||||
</a>
|
</a>
|
||||||
<a class="btn btn-sm btn-info"
|
<a class="btn btn-xs btn-info"
|
||||||
href="{{ route('daftar-pustaka.edit', $item->id) }}">
|
href="{{ route('daftar-pustaka.edit', $item->id) }}">
|
||||||
<i class="ki-filled ki-pencil">
|
<i class="ki-filled ki-pencil">
|
||||||
</i>
|
</i>
|
||||||
@@ -120,22 +131,24 @@
|
|||||||
<div class="card-body flex items-center flex-wrap justify-between p-2 pe-5 gap-4.5">
|
<div class="card-body flex items-center flex-wrap justify-between p-2 pe-5 gap-4.5">
|
||||||
<div class="flex items-center gap-3.5">
|
<div class="flex items-center gap-3.5">
|
||||||
<div
|
<div
|
||||||
class="kt-card flex items-center justify-center bg-accent/50 h-[70px] w-[90px] shadow-none">
|
class="card bg-gray-200 flex items-center justify-center bg-accent/50 h-[70px] w-[90px] shadow-none">
|
||||||
<a class="show-pustaka h-[90px] w-full block"
|
<a class="show-pustaka h-[90px] w-full block"
|
||||||
href="{{ route('daftar-pustaka.show', $item->id) }}"
|
href="{{ route('daftar-pustaka.show', $item->id) }}"
|
||||||
data-url="{{ $item->attachment }}">
|
data-url="{{ $item->attachment }}">
|
||||||
<div class="p-4 h-full w-full flex items-center justify-center overflow-hidden">
|
<div class="p-4 h-full w-full flex items-center justify-center overflow-hidden">
|
||||||
<div class="preview-content h-full w-full"></div>
|
<div class=" text-red-500 flex items-center justify-center rounded">
|
||||||
|
<i class="ki-filled ki-document text-3xl"></i>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex flex-col gap-2 cursor-pointer">
|
|
||||||
<a href="{{ route('daftar-pustaka.show', $item->id) }}">
|
<a href="{{ route('daftar-pustaka.show', $item->id) }}">
|
||||||
|
<div class="flex flex-col gap-2 cursor-pointer">
|
||||||
<div class="flex items-center mt-1">
|
<div class="flex items-center mt-1">
|
||||||
<a class="hover:text-primary text-sm font-medium text-mono leading-5.5">
|
<a class="hover:text-primary text-sm font-medium text-mono leading-5.5">
|
||||||
{{ $item->judul }}
|
{{ $item->judul }}
|
||||||
</a>
|
|
||||||
</div>
|
</div>
|
||||||
|
</a>
|
||||||
<div class="flex items-center flex-wrap gap-3">
|
<div class="flex items-center flex-wrap gap-3">
|
||||||
<span class="kt-badge kt-badge-warning kt-badge-sm rounded-full gap-1">
|
<span class="kt-badge kt-badge-warning kt-badge-sm rounded-full gap-1">
|
||||||
<span class="text-xs font-medium text-foreground">
|
<span class="text-xs font-medium text-foreground">
|
||||||
@@ -144,8 +157,8 @@
|
|||||||
</span>
|
</span>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</a>
|
|
||||||
</div>
|
</div>
|
||||||
|
</a>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex items-center gap-1.5">
|
<div class="flex items-center gap-1.5">
|
||||||
<p class="badge rounded-full badge-sm badge-outline badge-success text-xs text-gray-700">
|
<p class="badge rounded-full badge-sm badge-outline badge-success text-xs text-gray-700">
|
||||||
@@ -202,7 +215,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="{{ asset('vendor/pdfobject.min.js') }}"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
@@ -236,30 +248,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
document.addEventListener('DOMContentLoaded', function() {
|
|
||||||
document.querySelectorAll('.show-pustaka').forEach(function(element) {
|
|
||||||
const url = element.getAttribute('data-url');
|
|
||||||
const previewContent = element.querySelector('.preview-content');
|
|
||||||
|
|
||||||
if (!previewContent || !url) return;
|
|
||||||
|
|
||||||
const fileExtension = url.split('.').pop().toLowerCase();
|
|
||||||
|
|
||||||
if (fileExtension === 'pdf') {
|
|
||||||
PDFObject.embed(url, previewContent, {
|
|
||||||
height: "100%",
|
|
||||||
width: "100%"
|
|
||||||
});
|
|
||||||
} else if (['jpg', 'jpeg', 'png', 'gif'].includes(fileExtension)) {
|
|
||||||
previewContent.innerHTML = `
|
|
||||||
<img src="${url}" alt="Preview"
|
|
||||||
class="w-full h-full object-cover rounded" />
|
|
||||||
`;
|
|
||||||
} else {
|
|
||||||
previewContent.innerHTML = '<p class="text-center">Unsupported file type</p>';
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
function showGrid() {
|
function showGrid() {
|
||||||
document.getElementById("daftar_pustaka_grid").classList.remove("hidden");
|
document.getElementById("daftar_pustaka_grid").classList.remove("hidden");
|
||||||
|
|||||||
@@ -1,12 +1,10 @@
|
|||||||
@extends('layouts.main')
|
@extends('layouts.main')
|
||||||
|
|
||||||
@section('breadcrumbs')
|
@section('breadcrumbs')
|
||||||
{{-- {{ Breadcrumbs::render(request()->route()->getName()) }} --}}
|
|
||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@section('content')
|
@section('content')
|
||||||
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||||
|
|
||||||
<form
|
<form
|
||||||
action="{{ isset($daftarPustaka->id) ? route('daftar-pustaka.update', $daftarPustaka->id) : route('daftar-pustaka.store') }}"
|
action="{{ isset($daftarPustaka->id) ? route('daftar-pustaka.update', $daftarPustaka->id) : route('daftar-pustaka.store') }}"
|
||||||
method="POST">
|
method="POST">
|
||||||
@@ -17,27 +15,47 @@
|
|||||||
{{ $daftarPustaka->judul ?? '' }}
|
{{ $daftarPustaka->judul ?? '' }}
|
||||||
</h3>
|
</h3>
|
||||||
<div class="flex items-center gap-2">
|
<div class="flex items-center gap-2">
|
||||||
<a href="{{ route('daftar-pustaka.index') }}" class="btn btn-xs btn-info"><i
|
<a href="{{ route('daftar-pustaka.index') }}" class="btn btn-xs btn-info">
|
||||||
class="ki-filled ki-exit-left"></i> Back</a>
|
<i class="ki-filled ki-exit-left"></i> Back
|
||||||
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="card-body grid gap-5">
|
<div class="card-body grid gap-5">
|
||||||
<div
|
<div class="min-w-3xl">
|
||||||
class=" min-w-3xl w-[1280px] h-[768px]">
|
|
||||||
<div class="p-4 h-full flex flex-col">
|
<div class="p-4 h-full flex flex-col">
|
||||||
<div class="flex justify-between items-center mb-4">
|
<div class="flex justify-between items-center mb-4">
|
||||||
<button type="button" id="downloadBtn" class="btn btn-primary btn-sm">
|
<a href="{{ asset('storage/' . $daftarPustaka->attachment) }}" class="btn btn-primary btn-sm">
|
||||||
<i class="ki-duotone ki-cloud-download me-1"><span class="path1"></span><span
|
<i class="ki-duotone ki-cloud-download me-1"></i>
|
||||||
class="path2"></span></i>
|
|
||||||
Download File
|
Download File
|
||||||
</button>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
<div id="previewContent" class="flex-grow"></div>
|
|
||||||
|
@php
|
||||||
|
$fileExtension = pathinfo($daftarPustaka->attachment, PATHINFO_EXTENSION);
|
||||||
|
$isPdf = strtolower($fileExtension) == 'pdf';
|
||||||
|
$imageExtensions = ['jpg', 'jpeg', 'png', 'gif', 'webp'];
|
||||||
|
$isImage = in_array(strtolower($fileExtension), $imageExtensions);
|
||||||
|
$fileUrl = asset('storage/' . $daftarPustaka->attachment);
|
||||||
|
@endphp
|
||||||
|
|
||||||
|
@if ($isPdf)
|
||||||
|
<canvas id="pdfViewer" class="w-full border rounded touch-pan-y"></canvas>
|
||||||
|
<div class="flex justify-center gap-3 mt-3">
|
||||||
|
<button type="button" id="prevPage" class="btn btn-primary btn-sm">Previous</button>
|
||||||
|
<span>Page: <span id="pageNum">1</span> / <span id="pageCount">0</span></span>
|
||||||
|
<button type="button" id="nextPage" class="btn btn-primary btn-sm">Next</button>
|
||||||
|
</div>
|
||||||
|
@elseif ($isImage)
|
||||||
|
<img src="{{ $fileUrl }}" class="w-full object-contain rounded" />
|
||||||
|
@else
|
||||||
|
<p class="text-red-500">File tidak bisa ditampilkan, silakan
|
||||||
|
<a href="{{ $fileUrl }}" class="text-blue-500 underline" download>unduh di sini</a>.
|
||||||
|
</p>
|
||||||
|
@endif
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="border border-t">
|
<div class="border border-t"></div>
|
||||||
</div>
|
|
||||||
<div>
|
<div>
|
||||||
{{ $daftarPustaka->deskripsi ?? '' }}
|
{{ $daftarPustaka->deskripsi ?? '' }}
|
||||||
</div>
|
</div>
|
||||||
@@ -48,23 +66,99 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="{{ asset('vendor/pdfobject.min.js') }}"></script>
|
<!-- PDF.js CDN -->
|
||||||
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/pdf.js/3.11.174/pdf.min.js"></script>
|
||||||
<script>
|
<script>
|
||||||
document.addEventListener('DOMContentLoaded', function () {
|
document.addEventListener('DOMContentLoaded', function () {
|
||||||
let url = @json($daftarPustaka->attachment);
|
const url = @json($fileUrl);
|
||||||
console.log(url);
|
|
||||||
|
|
||||||
const fileExtension = url.split('.').pop().toLowerCase();
|
if (url.endsWith('.pdf')) {
|
||||||
const previewContent = document.getElementById('previewContent');
|
const pdfjsLib = window['pdfjs-dist/build/pdf'];
|
||||||
|
pdfjsLib.GlobalWorkerOptions.workerSrc = 'https://cdnjs.cloudflare.com/ajax/libs/pdf.js/3.11.174/pdf.worker.min.js';
|
||||||
|
|
||||||
if (['pdf'].includes(fileExtension)) {
|
let pdfDoc = null;
|
||||||
PDFObject.embed(url, "#previewContent");
|
let pageNum = 1;
|
||||||
} else if (['jpg', 'jpeg', 'png', 'gif'].includes(fileExtension)) {
|
let pageRendering = false;
|
||||||
previewContent.innerHTML =
|
let pageNumPending = null;
|
||||||
`<img src="${url}" alt="Preview" class="max-w-full max-h-full object-contain">`;
|
const scale = 1.3;
|
||||||
|
const canvas = document.getElementById('pdfViewer');
|
||||||
|
const ctx = canvas.getContext('2d');
|
||||||
|
|
||||||
|
function renderPage(num) {
|
||||||
|
pageRendering = true;
|
||||||
|
pdfDoc.getPage(num).then(function (page) {
|
||||||
|
const viewport = page.getViewport({ scale: scale });
|
||||||
|
canvas.height = viewport.height;
|
||||||
|
canvas.width = viewport.width;
|
||||||
|
|
||||||
|
const renderContext = {
|
||||||
|
canvasContext: ctx,
|
||||||
|
viewport: viewport
|
||||||
|
};
|
||||||
|
const renderTask = page.render(renderContext);
|
||||||
|
|
||||||
|
renderTask.promise.then(function () {
|
||||||
|
pageRendering = false;
|
||||||
|
document.getElementById('pageNum').textContent = num;
|
||||||
|
|
||||||
|
if (pageNumPending !== null) {
|
||||||
|
renderPage(pageNumPending);
|
||||||
|
pageNumPending = null;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function queueRenderPage(num) {
|
||||||
|
if (pageRendering) {
|
||||||
|
pageNumPending = num;
|
||||||
} else {
|
} else {
|
||||||
previewContent.innerHTML = '<p class="text-center">Unsupported file type</p>';
|
renderPage(num);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function onPrevPage() {
|
||||||
|
if (pageNum <= 1) return;
|
||||||
|
pageNum--;
|
||||||
|
queueRenderPage(pageNum);
|
||||||
|
}
|
||||||
|
|
||||||
|
function onNextPage() {
|
||||||
|
if (pageNum >= pdfDoc.numPages) return;
|
||||||
|
pageNum++;
|
||||||
|
queueRenderPage(pageNum);
|
||||||
|
}
|
||||||
|
|
||||||
|
document.getElementById('prevPage').addEventListener('click', onPrevPage);
|
||||||
|
document.getElementById('nextPage').addEventListener('click', onNextPage);
|
||||||
|
|
||||||
|
// Swipe gesture
|
||||||
|
let touchStartX = 0;
|
||||||
|
let touchEndX = 0;
|
||||||
|
|
||||||
|
canvas.addEventListener('touchstart', function (e) {
|
||||||
|
touchStartX = e.changedTouches[0].screenX;
|
||||||
|
});
|
||||||
|
|
||||||
|
canvas.addEventListener('touchend', function (e) {
|
||||||
|
touchEndX = e.changedTouches[0].screenX;
|
||||||
|
handleSwipe();
|
||||||
|
});
|
||||||
|
|
||||||
|
function handleSwipe() {
|
||||||
|
const swipeThreshold = 50; // min distance for swipe
|
||||||
|
if (touchEndX < touchStartX - swipeThreshold) {
|
||||||
|
onNextPage();
|
||||||
|
} else if (touchEndX > touchStartX + swipeThreshold) {
|
||||||
|
onPrevPage();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pdfjsLib.getDocument(url).promise.then(function (pdfDoc_) {
|
||||||
|
pdfDoc = pdfDoc_;
|
||||||
|
document.getElementById('pageCount').textContent = pdfDoc.numPages;
|
||||||
|
renderPage(pageNum);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
@@ -44,15 +44,6 @@
|
|||||||
@endforeach
|
@endforeach
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</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>
|
</div>
|
||||||
|
|
||||||
<!-- Buttons row at the bottom -->
|
<!-- Buttons row at the bottom -->
|
||||||
@@ -73,7 +64,7 @@
|
|||||||
<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 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">
|
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
||||||
<h3 class="card-title">
|
<h3 class="card-title">
|
||||||
Laporan Hasil Penilaian Jaminan Internal & External
|
Rekap Penyelesaian External
|
||||||
</h3>
|
</h3>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -89,130 +80,53 @@
|
|||||||
<span class="sort"> <span class="sort-label"> Nomor Registrasi </span>
|
<span class="sort"> <span class="sort-label"> Nomor Registrasi </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</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">
|
<th class="min-w-[150px]" data-datatable-column="branch">
|
||||||
<span class="sort"> <span class="sort-label"> Cabang </span>
|
<span class="sort"> <span class="sort-label"> Cabang </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</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">
|
<th class="min-w-[150px]" data-datatable-column="name">
|
||||||
<span class="sort"> <span class="sort-label"> Nama Debitur </span>
|
<span class="sort"> <span class="sort-label"> Nama Debitur </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_permohonan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal KSL </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="pemohon">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nomor KSL </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="cif">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nominal KSL </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
|
||||||
<th class="min-w-[150px]" data-datatable-column="jenis_penilaian">
|
<th class="min-w-[150px]" data-datatable-column="jenis_penilaian">
|
||||||
<span class="sort"> <span class="sort-label"> Jenis Penilaian </span>
|
<span class="sort"> <span class="sort-label">Tanggal Penyelesaian </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
<th class="min-w-[150px]" data-datatable-column="tujuan_penilaian">
|
<th class="min-w-[150px]" data-datatable-column="tujuan_penilaian">
|
||||||
<span class="sort"> <span class="sort-label"> Tujuan Penilaian </span>
|
<span class="sort"> <span class="sort-label"> Nominal Penyelesaian </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
<th class="min-w-[150px]" data-datatable-column="jenis_fasilitas_kredit">
|
<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"> <span class="sort-label"> No. Rekening (Tujuan Akhir) </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"> Sisa KSL </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
<th class="min-w-[150px]" data-datatable-column="jenis_agunan">
|
<th class="min-w-[150px]" data-datatable-column="jenis_agunan">
|
||||||
<span class="sort"> <span class="sort-label"> Jenis Agunan </span>
|
<span class="sort"> <span class="sort-label"> Memo </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
<th class="min-w-[150px]" data-datatable-column="alamat_agunan">
|
<th class="min-w-[150px]" data-datatable-column="alamat_agunan">
|
||||||
<span class="sort"> <span class="sort-label"> Alamat Agunan </span>
|
<span class="sort"> <span class="sort-label"> Status</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>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
|
|
||||||
<th class="min-w-[150px]" data-datatable-column="catatan">
|
<th class="min-w-[150px]" data-datatable-column="catatan">
|
||||||
<span class="sort"> <span class="sort-label"> Catatan </span>
|
<span class="sort"> <span class="sort-label"> Catatan </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
@@ -266,144 +180,41 @@
|
|||||||
nomor_registrasi: {
|
nomor_registrasi: {
|
||||||
title: 'Nomor Registrasi',
|
title: 'Nomor Registrasi',
|
||||||
},
|
},
|
||||||
tanggal_permohonan: {
|
branch: {
|
||||||
|
title: 'Cabang',
|
||||||
|
},
|
||||||
|
name: {
|
||||||
|
title: 'Nama Debitur',
|
||||||
|
},
|
||||||
|
tanggal_ksl: {
|
||||||
title: 'Tanggal Permohonan',
|
title: 'Tanggal Permohonan',
|
||||||
render: (item, data) => {
|
render: (item, data) => {
|
||||||
return data.tanggal_permohonan ? window.formatTanggalIndonesia(data.tanggal_permohonan) : '-';
|
return data.tanggal_permohonan ? window.formatTanggalIndonesia(data.tanggal_permohonan) : '-';
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
branch: {
|
nomor_ksl: {
|
||||||
title: 'Cabang',
|
|
||||||
},
|
|
||||||
pemohon: {
|
|
||||||
title: 'Pemohon',
|
|
||||||
},
|
|
||||||
cif: {
|
|
||||||
title: 'CIF',
|
title: 'CIF',
|
||||||
},
|
},
|
||||||
name: {
|
nominal_ksl: {
|
||||||
title: 'Nama Debitur',
|
|
||||||
},
|
|
||||||
jenis_penilaian: {
|
|
||||||
title: 'Jenis Penilaian',
|
title: 'Jenis Penilaian',
|
||||||
},
|
},
|
||||||
tujuan_penilaian: {
|
tanggal_penyelesaian: {
|
||||||
title: 'Tujuan Penilaian',
|
title: 'Tujuan Penilaian',
|
||||||
},
|
},
|
||||||
jenis_fasilitas_kredit: {
|
nominal_penyelesaian: {
|
||||||
title: 'Jenis Fasilitas Kredit',
|
title: 'Jenis Fasilitas Kredit',
|
||||||
},
|
},
|
||||||
jenis_agunan: {
|
nomor_rekening: {
|
||||||
|
title: 'Nomor Rekening',
|
||||||
|
},
|
||||||
|
sisa_ksl: {
|
||||||
title: 'Jenis Agunan',
|
title: 'Jenis Agunan',
|
||||||
},
|
},
|
||||||
alamat_agunan: {
|
memo: {
|
||||||
title: 'Alamat Agunan',
|
title: 'Memo',
|
||||||
},
|
},
|
||||||
bukti_kepemilikan: {
|
status: {
|
||||||
title: 'Bukti Kepemilikan',
|
title: 'Status',
|
||||||
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: {
|
catatan: {
|
||||||
title: 'Catatan',
|
title: 'Catatan',
|
||||||
|
|||||||
@@ -44,15 +44,7 @@
|
|||||||
@endforeach
|
@endforeach
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</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>
|
</div>
|
||||||
|
|
||||||
<!-- Buttons row at the bottom -->
|
<!-- Buttons row at the bottom -->
|
||||||
@@ -73,7 +65,7 @@
|
|||||||
<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 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">
|
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
||||||
<h3 class="card-title">
|
<h3 class="card-title">
|
||||||
Laporan Hasil Penilaian Jaminan Internal & External
|
Rekap Penyelesaian Internal
|
||||||
</h3>
|
</h3>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -89,130 +81,49 @@
|
|||||||
<span class="sort"> <span class="sort-label"> Nomor Registrasi </span>
|
<span class="sort"> <span class="sort-label"> Nomor Registrasi </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</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">
|
<th class="min-w-[150px]" data-datatable-column="branch">
|
||||||
<span class="sort"> <span class="sort-label"> Cabang </span>
|
<span class="sort"> <span class="sort-label"> Cabang </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</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">
|
<th class="min-w-[150px]" data-datatable-column="name">
|
||||||
<span class="sort"> <span class="sort-label"> Nama Debitur </span>
|
<span class="sort"> <span class="sort-label"> Nama Debitur </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tanggal_permohonan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal KSL </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="pemohon">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nomor KSL </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="cif">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nominal KSL </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
|
||||||
<th class="min-w-[150px]" data-datatable-column="jenis_penilaian">
|
<th class="min-w-[150px]" data-datatable-column="jenis_penilaian">
|
||||||
<span class="sort"> <span class="sort-label"> Jenis Penilaian </span>
|
<span class="sort"> <span class="sort-label">Tanggal Penyelesaian </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
<th class="min-w-[150px]" data-datatable-column="tujuan_penilaian">
|
<th class="min-w-[150px]" data-datatable-column="tujuan_penilaian">
|
||||||
<span class="sort"> <span class="sort-label"> Tujuan Penilaian </span>
|
<span class="sort"> <span class="sort-label"> Nominal Penyelesaian </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
<th class="min-w-[150px]" data-datatable-column="jenis_fasilitas_kredit">
|
<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"> <span class="sort-label"> Sisa KSL </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
<th class="min-w-[150px]" data-datatable-column="jenis_agunan">
|
<th class="min-w-[150px]" data-datatable-column="jenis_agunan">
|
||||||
<span class="sort"> <span class="sort-label"> Jenis Agunan </span>
|
<span class="sort"> <span class="sort-label"> Memo </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
<th class="min-w-[150px]" data-datatable-column="alamat_agunan">
|
<th class="min-w-[150px]" data-datatable-column="alamat_agunan">
|
||||||
<span class="sort"> <span class="sort-label"> Alamat Agunan </span>
|
<span class="sort"> <span class="sort-label"> Status</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>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
|
|
||||||
<th class="min-w-[150px]" data-datatable-column="catatan">
|
<th class="min-w-[150px]" data-datatable-column="catatan">
|
||||||
<span class="sort"> <span class="sort-label"> Catatan </span>
|
<span class="sort"> <span class="sort-label"> Catatan </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
@@ -266,144 +177,38 @@
|
|||||||
nomor_registrasi: {
|
nomor_registrasi: {
|
||||||
title: 'Nomor Registrasi',
|
title: 'Nomor Registrasi',
|
||||||
},
|
},
|
||||||
tanggal_permohonan: {
|
branch: {
|
||||||
|
title: 'Cabang',
|
||||||
|
},
|
||||||
|
name: {
|
||||||
|
title: 'Nama Debitur',
|
||||||
|
},
|
||||||
|
tanggal_ksl: {
|
||||||
title: 'Tanggal Permohonan',
|
title: 'Tanggal Permohonan',
|
||||||
render: (item, data) => {
|
render: (item, data) => {
|
||||||
return data.tanggal_permohonan ? window.formatTanggalIndonesia(data.tanggal_permohonan) : '-';
|
return data.tanggal_permohonan ? window.formatTanggalIndonesia(data.tanggal_permohonan) : '-';
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
branch: {
|
nomor_ksl: {
|
||||||
title: 'Cabang',
|
|
||||||
},
|
|
||||||
pemohon: {
|
|
||||||
title: 'Pemohon',
|
|
||||||
},
|
|
||||||
cif: {
|
|
||||||
title: 'CIF',
|
title: 'CIF',
|
||||||
},
|
},
|
||||||
name: {
|
nominal_ksl: {
|
||||||
title: 'Nama Debitur',
|
|
||||||
},
|
|
||||||
jenis_penilaian: {
|
|
||||||
title: 'Jenis Penilaian',
|
title: 'Jenis Penilaian',
|
||||||
},
|
},
|
||||||
tujuan_penilaian: {
|
tanggal_penyelesaian: {
|
||||||
title: 'Tujuan Penilaian',
|
title: 'Tujuan Penilaian',
|
||||||
},
|
},
|
||||||
jenis_fasilitas_kredit: {
|
nominal_penyelesaian: {
|
||||||
title: 'Jenis Fasilitas Kredit',
|
title: 'Jenis Fasilitas Kredit',
|
||||||
},
|
},
|
||||||
jenis_agunan: {
|
sisa_ksl: {
|
||||||
title: 'Jenis Agunan',
|
title: 'Jenis Agunan',
|
||||||
},
|
},
|
||||||
alamat_agunan: {
|
memo: {
|
||||||
title: 'Alamat Agunan',
|
title: 'Memo',
|
||||||
},
|
},
|
||||||
bukti_kepemilikan: {
|
status: {
|
||||||
title: 'Bukti Kepemilikan',
|
title: 'Status',
|
||||||
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: {
|
catatan: {
|
||||||
title: 'Catatan',
|
title: 'Catatan',
|
||||||
|
|||||||
@@ -35,21 +35,19 @@
|
|||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th class="min-w-[100px]">Nama Debitur</th>
|
<th class="min-w-[100px]">Nama Debitur</th>
|
||||||
<th class="min-w-[100px]">Tujuan Penilaian</th>
|
<th class="min-w-[100px]">Cabang</th>
|
||||||
<th class="min-w-[100px]">Status Bayar</th>
|
<th class="min-w-[100px]">Lokasi Jaminan</th>
|
||||||
<th class="min-w-[100px]">Jenis Asset</th>
|
<th class="min-w-[100px]">TUjuan Penilaian</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]">Tgl Kunjungan</th>
|
||||||
<th class="min-w-[100px]">Tgl Reported</th>
|
<th class="min-w-[100px]">Tgl Lpj Done</th>
|
||||||
<th class="min-w-[100px]">Progress</th>
|
<th class="min-w-[100px]">SLA Buku Kjpp</th>
|
||||||
<th class="min-w-[100px]">SLA Laporan</th>
|
<th class="min-w-[100px]">Status</th>
|
||||||
<th class="min-w-[100px]">SLA Paparan</th>
|
<th class="min-w-[100px]">Poin</th>
|
||||||
<th class="min-w-[100px]">Approve</th>
|
<th class="min-w-[100px]">SLA INTERNAL</th>
|
||||||
|
<th class="min-w-[100px]">SLA PENDAMPINGAN KJPP</th>
|
||||||
|
<th class="min-w-[100px]">Absensi</th>
|
||||||
|
<th class="min-w-[100px]">Zabtu</th>
|
||||||
<th class="min-w-[50px] text-center">Keterangan</th>
|
<th class="min-w-[50px] text-center">Keterangan</th>
|
||||||
<th class="min-w-[50px] text-center">Action</th>
|
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
@@ -189,20 +187,7 @@
|
|||||||
return `${window.formatTanggalIndonesia(data.paparan)}`;
|
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: {
|
keterangan: {
|
||||||
|
|||||||
@@ -219,7 +219,8 @@
|
|||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script type="module">
|
<script type="module">
|
||||||
const element = document.querySelector('#laporan-penilai-jaminan-table');
|
const element = document.querySelector('#laporan-penilai-jaminan-table');
|
||||||
const searchInput = document.getElementById('search');;
|
|
||||||
|
const searchInput = document.getElementById('search');
|
||||||
const startDateInput = document.getElementById('start_date');
|
const startDateInput = document.getElementById('start_date');
|
||||||
const endDateInput = document.getElementById('end_date');
|
const endDateInput = document.getElementById('end_date');
|
||||||
const branchFilter = document.getElementById('branch_filter');
|
const branchFilter = document.getElementById('branch_filter');
|
||||||
@@ -227,7 +228,6 @@
|
|||||||
const filterTanggalButton = document.getElementById('filter_tanggal');
|
const filterTanggalButton = document.getElementById('filter_tanggal');
|
||||||
const exportButton = document.getElementById('export-btn');
|
const exportButton = document.getElementById('export-btn');
|
||||||
|
|
||||||
|
|
||||||
const selectAllCheckbox = document.getElementById('check-all');
|
const selectAllCheckbox = document.getElementById('check-all');
|
||||||
const statusCheckboxes = document.querySelectorAll('.status-checkbox');
|
const statusCheckboxes = document.querySelectorAll('.status-checkbox');
|
||||||
|
|
||||||
@@ -242,6 +242,11 @@
|
|||||||
const exportType = document.getElementById('export_type');
|
const exportType = document.getElementById('export_type');
|
||||||
const exportSearch = document.getElementById('export_search');
|
const exportSearch = document.getElementById('export_search');
|
||||||
const apiUrl = element.getAttribute('data-api-url');
|
const apiUrl = element.getAttribute('data-api-url');
|
||||||
|
|
||||||
|
// Simple pagination state management
|
||||||
|
let currentPage = 1;
|
||||||
|
let isReturningFromDetail = false;
|
||||||
|
|
||||||
const dataTableOptions = {
|
const dataTableOptions = {
|
||||||
apiEndpoint: apiUrl,
|
apiEndpoint: apiUrl,
|
||||||
pageSize: 5,
|
pageSize: 5,
|
||||||
@@ -293,7 +298,6 @@
|
|||||||
return data.debiture && data.debiture.name ? `${data.debiture.name}` : '-';
|
return data.debiture && data.debiture.name ? `${data.debiture.name}` : '-';
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
tujuan_penilaian_id: {
|
tujuan_penilaian_id: {
|
||||||
title: 'Tujuan Penilaian',
|
title: 'Tujuan Penilaian',
|
||||||
render: (item, data) => {
|
render: (item, data) => {
|
||||||
@@ -309,12 +313,10 @@
|
|||||||
}).join(', ');
|
}).join(', ');
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
laporan: {
|
laporan: {
|
||||||
title: 'Status',
|
title: 'Status',
|
||||||
render: (item, data) => {
|
render: (item, data) => {
|
||||||
let badgeClass = '';
|
let badgeClass = '';
|
||||||
|
|
||||||
const statusLaporan = data.penilai?.type_penilai || '-';
|
const statusLaporan = data.penilai?.type_penilai || '-';
|
||||||
|
|
||||||
switch (statusLaporan.toLowerCase()) {
|
switch (statusLaporan.toLowerCase()) {
|
||||||
@@ -343,7 +345,7 @@
|
|||||||
actions: {
|
actions: {
|
||||||
title: 'Action',
|
title: 'Action',
|
||||||
render: (item, data) => {
|
render: (item, data) => {
|
||||||
const status = data.status; // Anggap status berada di dalam objek data
|
const status = data.status;
|
||||||
const dokumenjaminan = data.dokumenjaminan || [];
|
const dokumenjaminan = data.dokumenjaminan || [];
|
||||||
|
|
||||||
return `
|
return `
|
||||||
@@ -355,13 +357,12 @@
|
|||||||
<a class="btn btn-sm btn-primary" href="surveyor/print-out-inspeksi/${data.id}/${dokumen.id}/${dokumen.jenis_jaminan_id}">
|
<a class="btn btn-sm btn-primary" href="surveyor/print-out-inspeksi/${data.id}/${dokumen.id}/${dokumen.jenis_jaminan_id}">
|
||||||
<i class="ki-outline ki-printer"></i>Inspeksi
|
<i class="ki-outline ki-printer"></i>Inspeksi
|
||||||
</a>
|
</a>
|
||||||
<a class="btn btn-sm btn-info" href="laporan-penilai-jaminan/show/${data.id}/${dokumen.id}/${dokumen.jenis_jaminan_id}" >
|
<a class="btn btn-sm btn-info detail-btn" href="laporan-penilai-jaminan/show/${data.id}/${dokumen.id}/${dokumen.jenis_jaminan_id}">
|
||||||
<i class="ki-filled ki-eye"></i>Lihat
|
<i class="ki-filled ki-eye"></i>Lihat
|
||||||
</a>
|
</a>
|
||||||
<a class="btn btn-sm btn-success" href="penilai/print-out-laporan/${data.id}/${dokumen.id}/${dokumen.jenis_jaminan_id}">
|
<a class="btn btn-sm btn-success" href="penilai/print-out-laporan/${data.id}/${dokumen.id}/${dokumen.jenis_jaminan_id}">
|
||||||
<i class="ki-filled ki-printer"></i>Laporan
|
<i class="ki-filled ki-printer"></i>Laporan
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
`;
|
`;
|
||||||
}).join('') : ''
|
}).join('') : ''
|
||||||
}
|
}
|
||||||
@@ -369,12 +370,82 @@
|
|||||||
`;
|
`;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
},
|
},
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
let dataTable = new KTDataTable(element, dataTableOptions);
|
let dataTable = new KTDataTable(element, dataTableOptions);
|
||||||
|
const fromDetail = true;
|
||||||
|
if (fromDetail) {
|
||||||
|
isReturningFromDetail = true;
|
||||||
|
console.log('Returning from detail page');
|
||||||
|
// Remove the parameter from URL
|
||||||
|
window.history.replaceState({}, document.title, window.location.pathname);
|
||||||
|
setTimeout(() => {
|
||||||
|
restoreCurrentPage();
|
||||||
|
isReturningFromDetail = false;
|
||||||
|
}, 500);
|
||||||
|
}
|
||||||
|
|
||||||
|
function getCurrentPageFromDOM() {
|
||||||
|
const activePage = document.querySelector('.pagination .btn.active');
|
||||||
|
if (activePage) {
|
||||||
|
const pageText = activePage.textContent.trim();
|
||||||
|
const pageNum = parseInt(pageText);
|
||||||
|
return isNaN(pageNum) ? 1 : pageNum;
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
function saveCurrentPage() {
|
||||||
|
const page = getCurrentPageFromDOM();
|
||||||
|
currentPage = page;
|
||||||
|
sessionStorage.setItem('currentTablePage', currentPage.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
function restoreCurrentPage() {
|
||||||
|
const savedPage = sessionStorage.getItem('currentTablePage');
|
||||||
|
if (savedPage && savedPage !== '1') {
|
||||||
|
currentPage = parseInt(savedPage);
|
||||||
|
console.log('Restoring to page:', currentPage);
|
||||||
|
|
||||||
|
// Use the goPage method to navigate to the saved page
|
||||||
|
dataTable.goPage(currentPage);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Listen for pagination events to track current page
|
||||||
|
element.addEventListener('pagination', function(e) {
|
||||||
|
const page = e.detail.page;
|
||||||
|
currentPage = page;
|
||||||
|
console.log('Page changed to:', page);
|
||||||
|
});
|
||||||
|
|
||||||
|
// Alternative: Listen for pagination button clicks
|
||||||
|
document.addEventListener('click', function(e) {
|
||||||
|
if (e.target.matches('.pagination .btn') && !e.target.closest('.detail-btn')) {
|
||||||
|
setTimeout(() => {
|
||||||
|
currentPage = getCurrentPageFromDOM();
|
||||||
|
console.log('Current page updated to:', currentPage);
|
||||||
|
}, 100);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Detail page redirection
|
||||||
|
document.addEventListener('click', function(e) {
|
||||||
|
if (e.target.closest('.detail-btn')) {
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
// Save current page before navigating
|
||||||
|
const currentPageNum = getCurrentPageFromDOM();
|
||||||
|
currentPage = currentPageNum;
|
||||||
|
sessionStorage.setItem('currentTablePage', currentPage.toString());
|
||||||
|
console.log('Saving page before detail navigation:', currentPage);
|
||||||
|
|
||||||
|
const link = e.target.closest('.detail-btn');
|
||||||
|
const href = link.getAttribute('href');
|
||||||
|
window.location.href = href;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
// Search functionality
|
// Search functionality
|
||||||
searchInput.addEventListener('input', function() {
|
searchInput.addEventListener('input', function() {
|
||||||
@@ -392,7 +463,6 @@
|
|||||||
const branch = branchFilter.value;
|
const branch = branchFilter.value;
|
||||||
const laporan = Array.from(laporanFilter.selectedOptions).map(option => option.value);
|
const laporan = Array.from(laporanFilter.selectedOptions).map(option => option.value);
|
||||||
|
|
||||||
|
|
||||||
let filters = {};
|
let filters = {};
|
||||||
if (searchInput.value) {
|
if (searchInput.value) {
|
||||||
filters.search = searchInput.value;
|
filters.search = searchInput.value;
|
||||||
@@ -438,10 +508,8 @@
|
|||||||
|
|
||||||
if (selectedStatuses.length === 0) {
|
if (selectedStatuses.length === 0) {
|
||||||
dataTable.search('');
|
dataTable.search('');
|
||||||
console.log(selectedStatuses);
|
|
||||||
} else {
|
} else {
|
||||||
dataTable.search(selectedStatuses.join(','), true);
|
dataTable.search(selectedStatuses.join(','), true);
|
||||||
console.log(selectedStatuses);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
dataTable.reload();
|
dataTable.reload();
|
||||||
@@ -451,16 +519,13 @@
|
|||||||
selectAllCheckbox.checked = allChecked;
|
selectAllCheckbox.checked = allChecked;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Single export button functionality
|
// Export functionality
|
||||||
exportButton.addEventListener('click', function(e) {
|
exportButton.addEventListener('click', function(e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
|
||||||
// Check if any rows are selected
|
|
||||||
const selectedIds = getSelectedRowIds();
|
const selectedIds = getSelectedRowIds();
|
||||||
|
|
||||||
// Determine export type based on context
|
|
||||||
if (selectedIds.length > 0) {
|
if (selectedIds.length > 0) {
|
||||||
// If rows are selected, export those
|
|
||||||
exportData({
|
exportData({
|
||||||
selected_ids: selectedIds,
|
selected_ids: selectedIds,
|
||||||
export_type: 'selected'
|
export_type: 'selected'
|
||||||
@@ -476,14 +541,11 @@
|
|||||||
export_type: 'filtered'
|
export_type: 'filtered'
|
||||||
});
|
});
|
||||||
} else if (searchInput.value) {
|
} else if (searchInput.value) {
|
||||||
// If only search is applied, export filtered results
|
|
||||||
exportData({
|
exportData({
|
||||||
search: searchInput.value,
|
search: searchInput.value,
|
||||||
export_type: 'filtered'
|
export_type: 'filtered'
|
||||||
});
|
});
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
// If no selection and no filters, export all
|
|
||||||
exportData({
|
exportData({
|
||||||
export_type: 'all'
|
export_type: 'all'
|
||||||
});
|
});
|
||||||
@@ -491,7 +553,6 @@
|
|||||||
});
|
});
|
||||||
|
|
||||||
function exportData(filters = {}) {
|
function exportData(filters = {}) {
|
||||||
// Set filter values in the hidden form
|
|
||||||
exportStartDate.value = filters.start_date || '';
|
exportStartDate.value = filters.start_date || '';
|
||||||
exportEndDate.value = filters.end_date || '';
|
exportEndDate.value = filters.end_date || '';
|
||||||
exportStatus.value = filters.status ? filters.status.join(',') : '';
|
exportStatus.value = filters.status ? filters.status.join(',') : '';
|
||||||
@@ -500,7 +561,6 @@
|
|||||||
exportSelectedIds.value = filters.selected_ids ? filters.selected_ids.join(',') : '';
|
exportSelectedIds.value = filters.selected_ids ? filters.selected_ids.join(',') : '';
|
||||||
exportType.value = filters.export_type || 'all';
|
exportType.value = filters.export_type || 'all';
|
||||||
exportSearch.value = filters.search || '';
|
exportSearch.value = filters.search || '';
|
||||||
// Submit the form
|
|
||||||
exportForm.submit();
|
exportForm.submit();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -514,7 +574,12 @@
|
|||||||
const checkboxes = document.querySelectorAll('[data-datatable-row-check="true"]:checked');
|
const checkboxes = document.querySelectorAll('[data-datatable-row-check="true"]:checked');
|
||||||
return Array.from(checkboxes).map(checkbox => checkbox.value);
|
return Array.from(checkboxes).map(checkbox => checkbox.value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Save page before leaving (only when not going to detail)
|
||||||
|
window.addEventListener('beforeunload', function() {
|
||||||
|
if (!isReturningFromDetail) {
|
||||||
|
saveCurrentPage();
|
||||||
|
}
|
||||||
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
||||||
@endpush
|
@endpush
|
||||||
|
|||||||
@@ -104,10 +104,6 @@
|
|||||||
<span class="sort"> <span class="sort-label"> Tujuan Penilaian </span>
|
<span class="sort"> <span class="sort-label"> Tujuan Penilaian </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</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">
|
<th class="min-w-[150px]" data-datatable-column="tanggal_laporan">
|
||||||
<span class="sort"> <span class="sort-label"> Tanggal Dokuemen </span>
|
<span class="sort"> <span class="sort-label"> Tanggal Dokuemen </span>
|
||||||
@@ -199,20 +195,16 @@
|
|||||||
tujuan_penilaian: {
|
tujuan_penilaian: {
|
||||||
title: 'Tujuan Penilaian',
|
title: 'Tujuan Penilaian',
|
||||||
},
|
},
|
||||||
jenis_agunan: {
|
|
||||||
title: 'Jenis Agunan',
|
|
||||||
},
|
|
||||||
|
|
||||||
tanggal_laporan: {
|
tanggal_laporan: {
|
||||||
title: 'Tanggal Laporan',
|
title: 'Tanggal Laporan',
|
||||||
render: (item, data) => {
|
render: (item, data) => {
|
||||||
return data.tanggal_laporan ? window.formatTanggalIndonesia(data.tanggal_laporan) : '-';
|
return data.tanggal_laporan ? window.formatTanggalIndonesia(data.tanggal_laporan) : '-';
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
tanggal_review: {
|
tanggal_approval: {
|
||||||
title: 'Tanggal Review',
|
title: 'Tanggal Approval',
|
||||||
render: (item, data) => {
|
render: (item, data) => {
|
||||||
return data.tanggal_review ? window.formatTanggalIndonesia(data.tanggal_review) : '-';
|
return data.tanggal_approval ? window.formatTanggalIndonesia(data.tanggal_approval) : '-';
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
tanggal_kunjungan: {
|
tanggal_kunjungan: {
|
||||||
@@ -225,7 +217,7 @@
|
|||||||
jangka_waktu: {
|
jangka_waktu: {
|
||||||
title: 'Jangka Waktu',
|
title: 'Jangka Waktu',
|
||||||
render: (item, data) => {
|
render: (item, data) => {
|
||||||
return data.jangka_waktu ?? '3';
|
return data.jangka_waktu ?? '-';
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
keterangan: {
|
keterangan: {
|
||||||
|
|||||||
@@ -6,63 +6,27 @@
|
|||||||
|
|
||||||
@section('content')
|
@section('content')
|
||||||
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||||
<!-- Filter Card -->
|
|
||||||
<div class="card border border-agi-100">
|
<!-- Data Table Card -->
|
||||||
<div class="card-header bg-agi-50 py-5">
|
<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') }}">
|
||||||
<h3 class="card-title"> Laporan User Pemohon</h3>
|
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
||||||
</div>
|
|
||||||
<div class="card-body grid gap-4">
|
<h3 class="card-title">
|
||||||
<!-- Search field at the top, full width -->
|
Laporan User
|
||||||
<div class="flex flex-col w-full">
|
</h3>
|
||||||
<label class="text-sm font-medium mb-1">Pencarian</label>
|
<div class="flex flex-wrap gap-2 lg:gap-5">
|
||||||
|
<div class="flex flex-wrap gap-2 lg:gap-5">
|
||||||
<label class="input input-sm">
|
<label class="input input-sm">
|
||||||
<i class="ki-filled ki-magnifier"></i>
|
<i class="ki-filled ki-magnifier"></i>
|
||||||
<input placeholder="Search Laporan User" id="search" type="text" value="">
|
<input placeholder="Search Laporan User" id="search" type="text" value="">
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
<a class="btn btn-sm btn-light" href="{{ route('laporan-user.export') }}" id="export-btn">
|
||||||
<!-- 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>
|
<i class="ki-outline ki-file-down fs-2 me-1"></i>
|
||||||
Export to Excel
|
Export to Excel
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</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>
|
||||||
|
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
@@ -73,136 +37,20 @@
|
|||||||
<th class="w-14">
|
<th class="w-14">
|
||||||
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox"/>
|
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox"/>
|
||||||
</th>
|
</th>
|
||||||
<th class="min-w-[150px]" data-datatable-column="nomor_registrasi">
|
<th class="min-w-[150px]" data-datatable-column="nik">
|
||||||
<span class="sort"> <span class="sort-label"> Nomor Registrasi </span>
|
<span class="sort"> <span class="sort-label"> NIK</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>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
<th class="min-w-[150px]" data-datatable-column="name">
|
<th class="min-w-[150px]" data-datatable-column="name">
|
||||||
<span class="sort"> <span class="sort-label"> Nama Debitur </span>
|
<span class="sort"> <span class="sort-label"> Nama User</span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
<th class="min-w-[150px]" data-datatable-column="jenis_penilaian">
|
<th class="min-w-[150px]" data-datatable-column="level">
|
||||||
<span class="sort"> <span class="sort-label"> Jenis Penilaian </span>
|
<span class="sort"> <span class="sort-label"> Level Group </span>
|
||||||
<span class="sort-icon"> </span> </span>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
<th class="min-w-[150px]" data-datatable-column="tujuan_penilaian">
|
<th class="min-w-[150px]" data-datatable-column="approval_limit">
|
||||||
<span class="sort"> <span class="sort-label"> Tujuan Penilaian </span>
|
<span class="sort"> <span class="sort-label"> Approval Limit </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>
|
<span class="sort-icon"> </span> </span>
|
||||||
</th>
|
</th>
|
||||||
</tr>
|
</tr>
|
||||||
@@ -250,151 +98,21 @@
|
|||||||
return checkbox.outerHTML.trim();
|
return checkbox.outerHTML.trim();
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
nomor_registrasi: {
|
nik: {
|
||||||
title: 'Nomor Registrasi',
|
title: 'Nomor Registrasi',
|
||||||
},
|
},
|
||||||
tanggal_permohonan: {
|
name: {
|
||||||
title: 'Tanggal Permohonan',
|
title: 'Nama',
|
||||||
|
},
|
||||||
|
level: {
|
||||||
|
title: 'level',
|
||||||
|
},
|
||||||
|
approval_limit: {
|
||||||
|
title: 'Approval Limit',
|
||||||
render: (item, data) => {
|
render: (item, data) => {
|
||||||
return data.tanggal_permohonan ? window.formatTanggalIndonesia(data.tanggal_permohonan) : '-';
|
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',
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -415,7 +133,6 @@
|
|||||||
if (startDate) {
|
if (startDate) {
|
||||||
filters.start_date = startDate;
|
filters.start_date = startDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (endDate) {
|
if (endDate) {
|
||||||
filters.end_date = endDate;
|
filters.end_date = endDate;
|
||||||
}
|
}
|
||||||
@@ -425,7 +142,6 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
dataTable.search(filters);
|
dataTable.search(filters);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -6,10 +6,10 @@
|
|||||||
|
|
||||||
|
|
||||||
@section('content')
|
@section('content')
|
||||||
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
<div class="grid gap-5 mx-auto w-full lg:gap-7.5">
|
||||||
<div class="card border border-agi-100 card-grid min-w-full" data-datatable="false" data-datatable-page-size="10"
|
<div class="min-w-full border card border-agi-100 card-grid" data-datatable="false" data-datatable-page-size="10"
|
||||||
data-datatable-state-save="false" id="laporan-table" data-api-url="{{ route('laporan.datatables') }}">
|
data-datatable-state-save="false" id="laporan-table" data-api-url="{{ route('laporan.datatables') }}">
|
||||||
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
<div class="flex-wrap py-5 card-header bg-agi-50">
|
||||||
<h3 class="card-title">
|
<h3 class="card-title">
|
||||||
Laporan
|
Laporan
|
||||||
</h3>
|
</h3>
|
||||||
@@ -28,7 +28,7 @@
|
|||||||
|
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<div class="scrollable-x-auto">
|
<div class="scrollable-x-auto">
|
||||||
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm"
|
<table class="table text-sm font-medium text-gray-700 align-middle table-auto table-border"
|
||||||
data-datatable-table="true">
|
data-datatable-table="true">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
@@ -74,13 +74,13 @@
|
|||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
<div
|
<div
|
||||||
class="card-footer justify-center md:justify-between flex-col md:flex-row gap-3 text-gray-600 text-2sm font-medium">
|
class="flex-col gap-3 justify-center font-medium text-gray-600 card-footer md:justify-between md:flex-row text-2sm">
|
||||||
<div class="flex items-center gap-2">
|
<div class="flex gap-2 items-center">
|
||||||
Show
|
Show
|
||||||
<select class="select select-sm w-16" data-datatable-size="true" name="perpage"> </select> per
|
<select class="w-16 select select-sm" data-datatable-size="true" name="perpage"> </select> per
|
||||||
page
|
page
|
||||||
</div>
|
</div>
|
||||||
<div class="flex items-center gap-4">
|
<div class="flex gap-4 items-center">
|
||||||
<span data-datatable-info="true"> </span>
|
<span data-datatable-info="true"> </span>
|
||||||
<div class="pagination" data-datatable-pagination="true">
|
<div class="pagination" data-datatable-pagination="true">
|
||||||
</div>
|
</div>
|
||||||
@@ -224,7 +224,7 @@
|
|||||||
status: {
|
status: {
|
||||||
title: 'Status',
|
title: 'Status',
|
||||||
render: (item, data) => {
|
render: (item, data) => {
|
||||||
return `<span class="badge badge-sm badge-default uppercase flex justify-center">${data.status}</span>`;
|
return `<span class="flex justify-center uppercase badge badge-sm badge-default">${data.status}</span>`;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
actions: {
|
actions: {
|
||||||
@@ -241,9 +241,9 @@
|
|||||||
|
|
||||||
|
|
||||||
if (data.noc) {
|
if (data.noc) {
|
||||||
if (!data.noc?.tanggal_penyelesaian && !data.noc?.memo_penyelesaian) {
|
if (!data.noc?.memo_penyelesaian) {
|
||||||
penyelesaian = `
|
penyelesaian = `
|
||||||
<a href="{{ route('noc.penyelesaian') }}?id=${data.noc.id}&permohonanId=${data.noc.permohonan_id}&persetujuanPenawaranId=${data.noc.persetujuan_penawaran_id}" class="btn btn-sm btn-warning">
|
<a href="{{ route('noc.index') }}/${data.noc.id}" class="btn btn-sm btn-warning">
|
||||||
Penyelesaian
|
Penyelesaian
|
||||||
</a>`;
|
</a>`;
|
||||||
}
|
}
|
||||||
@@ -263,7 +263,8 @@
|
|||||||
</a>`;
|
</a>`;
|
||||||
}
|
}
|
||||||
|
|
||||||
if((data.status_bayar=="sudah_bayar" || data.status_bayar=="tidak_bayar") && data.nilai_liquidasi >0) {
|
if ((data.status_bayar == "sudah_bayar" || data.status_bayar == "tidak_bayar") && data
|
||||||
|
.nilai_liquidasi > 0) {
|
||||||
if (data.penilai.type_penilai == 'resume' && !data.penilai.resume) {
|
if (data.penilai.type_penilai == 'resume' && !data.penilai.resume) {
|
||||||
laporanButton = `
|
laporanButton = `
|
||||||
<a href="penilai/print-out-laporan/${data.id}/${dokumenID}/${jenisJaminanID}" class="btn btn-sm btn-primary">
|
<a href="penilai/print-out-laporan/${data.id}/${dokumenID}/${jenisJaminanID}" class="btn btn-sm btn-primary">
|
||||||
@@ -279,7 +280,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
return `<div class="flex flex-wrap justify-end gap-1.5"> ${penyelesaian} ${resumeButton} ${laporanButton} </div>`;
|
return `<div class="flex flex-wrap gap-1.5 justify-end"> ${penyelesaian} ${resumeButton} ${laporanButton} </div>`;
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -15,110 +15,134 @@
|
|||||||
@endphp
|
@endphp
|
||||||
|
|
||||||
@section('content')
|
@section('content')
|
||||||
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
<div class="grid gap-5 mx-auto w-full lg:gap-7.5">
|
||||||
<div class="card border border-agi-100 pb-2.5">
|
<div class="pb-2.5 border card border-agi-100">
|
||||||
<div class="card-header bg-agi-50" id="basic_settings">
|
<div class="card-header bg-agi-50" id="basic_settings">
|
||||||
<div class="card-title flex flex-row gap-1.5">
|
<div class="flex flex-row gap-1.5 card-title">
|
||||||
{{ $hasMemo ? 'Proses Penyelesaian NOC' : 'NOC' }}
|
{{ $hasMemo ? 'Proses Penyelesaian NOC' : 'NOC' }}
|
||||||
</div>
|
</div>
|
||||||
<div class="flex items-center gap-2">
|
<div class="flex gap-2 items-center">
|
||||||
<a href="{{ route('noc.index') }}" class="btn btn-xs btn-info"><i class="ki-filled ki-exit-left"></i> Back</a>
|
<a href="{{ route('noc.index') }}" class="btn btn-xs btn-info"><i class="ki-filled ki-exit-left"></i>
|
||||||
|
Back</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<form action="{{ !$hasMemo ? route('noc.store') : route('noc.update',$persetujuanPenawaran) }}" method="POST" class="grid gap-5" enctype="multipart/form-data">
|
<form action="{{ !$hasMemo ? route('noc.store') : route('noc.update', $persetujuanPenawaran) }}"
|
||||||
|
method="POST" class="grid gap-5" enctype="multipart/form-data">
|
||||||
@csrf
|
@csrf
|
||||||
@if ($hasMemo)
|
@if ($hasMemo)
|
||||||
@method('PUT')
|
@method('PUT')
|
||||||
@endif
|
@endif
|
||||||
<input type="hidden" name="penawaran_id" value="{{ $persetujuanPenawaran->penawaran_id ?? old('penawaran_id') }}">
|
<input type="hidden" name="penawaran_id"
|
||||||
<input type="hidden" name="persetujuan_penawaran_id" value="{{ $persetujuanPenawaran->id ?? old('persetujuan_penawaran_id') }}">
|
value="{{ $persetujuanPenawaran->penawaran_id ?? old('penawaran_id') }}">
|
||||||
<input type="hidden" name="permohonan_id" value="{{ $persetujuanPenawaran->penawaran->permohonan->id ?? $persetujuanPenawaran->permohonan->id }}">
|
<input type="hidden" name="persetujuan_penawaran_id"
|
||||||
|
value="{{ $persetujuanPenawaran->id ?? old('persetujuan_penawaran_id') }}">
|
||||||
|
<input type="hidden" name="permohonan_id"
|
||||||
|
value="{{ $persetujuanPenawaran->penawaran->permohonan->id ?? $persetujuanPenawaran->permohonan->id }}">
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex flex-wrap gap-2.5 items-baseline lg:flex-nowrap">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
Status Bayar
|
Status Bayar
|
||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
<select class="input tomselect w-full @error('status_pembayar') border-danger bg-danger-light @enderror" name="status_pembayar" id="status_pembayar" {{ $hasMemo ? 'disabled' : '' }}>
|
<select
|
||||||
|
class="input tomselect w-full @error('status_pembayar') border-danger bg-danger-light @enderror"
|
||||||
|
name="status_pembayar" id="status_pembayar" {{ $hasMemo ? 'disabled' : '' }}>
|
||||||
<option value="">Pilih Status Bayar</option>
|
<option value="">Pilih Status Bayar</option>
|
||||||
<option value="sudah_bayar" {{ (old('status_pembayar') == 'sudah_bayar') || ($persetujuanPenawaran?->penawaran?->permohonan?->status_bayar == 'sudah_bayar') ? 'selected' : '' }}>Sudah Bayar</option>
|
<option value="sudah_bayar"
|
||||||
<option value="belum_bayar" {{ (old('status_pembayar') == 'belum_bayar') || ($persetujuanPenawaran?->penawaran?->permohonan?->status_bayar == 'belum_bayar') ? 'selected' : '' }}>Belum Bayar</option>
|
{{ old('status_pembayar') == 'sudah_bayar' || $persetujuanPenawaran?->penawaran?->permohonan?->status_bayar == 'sudah_bayar' ? 'selected' : '' }}>
|
||||||
|
Sudah Bayar</option>
|
||||||
|
<option value="belum_bayar"
|
||||||
|
{{ old('status_pembayar') == 'belum_bayar' || $persetujuanPenawaran?->penawaran?->permohonan?->status_bayar == 'belum_bayar' ? 'selected' : '' }}>
|
||||||
|
Belum Bayar</option>
|
||||||
</select>
|
</select>
|
||||||
@error('status_bayar')
|
@error('status_bayar')
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
<em class="text-sm alert text-danger">{{ $message }}</em>
|
||||||
@enderror
|
@enderror
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex flex-wrap gap-2.5 items-baseline lg:flex-nowrap">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
Bukti Pembayaran
|
Bukti Pembayaran
|
||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
@if (!empty($persetujuanPenawaran->bukti_bayar))
|
@if (!empty($persetujuanPenawaran->bukti_bayar))
|
||||||
<div class="mt-2 flex items-center">
|
<div class="flex items-center mt-2">
|
||||||
<a href="{{ Storage::url($persetujuanPenawaran->bukti_bayar) }}" target="_blank" class="badge badge-sm badge-outline badge-warning">
|
<a href="{{ Storage::url($persetujuanPenawaran->bukti_bayar) }}" target="_blank"
|
||||||
<i class="ki-filled ki-eye mr-2"></i> Lihat File
|
class="badge badge-sm badge-outline badge-warning">
|
||||||
|
<i class="mr-2 ki-filled ki-eye"></i> Lihat File
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
@endif
|
@endif
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex flex-wrap gap-2.5 items-baseline lg:flex-nowrap">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
Nominal Bayar
|
Nominal Bayar
|
||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
<input type="number" name="total_harus_bayar" id="total_harus_bayar" class="input w-full @error('total_harus_bayar') border-danger bg-danger-light @enderror" value="{{ old('total_harus_bayar', $persetujuanPenawaran->nominal_bayar ?? '') }}" readonly>
|
<input type="number" name="total_harus_bayar" id="total_harus_bayar"
|
||||||
|
class="input w-full @error('total_harus_bayar') border-danger bg-danger-light @enderror"
|
||||||
|
value="{{ old('total_harus_bayar', $persetujuanPenawaran->nominal_bayar ?? '') }}"
|
||||||
|
readonly>
|
||||||
@error('total_harus_bayar')
|
@error('total_harus_bayar')
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
<em class="text-sm alert text-danger">{{ $message }}</em>
|
||||||
@enderror
|
@enderror
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex flex-wrap gap-2.5 items-baseline lg:flex-nowrap">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
Nominal Diterima
|
Nominal Diterima
|
||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
<input type="number" name="nominal_bayar" id="nominal_bayar" class="input w-full @error('nominal_bayar') border-danger bg-danger-light @enderror" value="{{ old('nominal_bayar', $persetujuanPenawaran->noc->nominal_bayar ?? '') }}" placeholder="Masukkan nominal bayar" {{ $hasMemo ? 'readonly' : '' }}>
|
<input type="number" name="nominal_bayar" id="nominal_bayar"
|
||||||
|
class="input w-full @error('nominal_bayar') border-danger bg-danger-light @enderror"
|
||||||
|
value="{{ old('nominal_bayar', $persetujuanPenawaran->noc->nominal_bayar ?? '') }}"
|
||||||
|
placeholder="Masukkan nominal bayar" {{ $hasMemo ? 'readonly' : '' }}>
|
||||||
@error('nominal_bayar')
|
@error('nominal_bayar')
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
<em class="text-sm alert text-danger">{{ $message }}</em>
|
||||||
@enderror
|
@enderror
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex flex-wrap gap-2.5 items-baseline lg:flex-nowrap">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
Tanggal Pembayaran
|
Tanggal Pembayaran
|
||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
<input type="date" name="tanggal_pembayaran" id="tanggal_pembayaran" class="input w-full @error('tanggal_pembayaran') border-danger bg-danger-light @enderror" value="{{ old('tanggal_pembayaran', isset($persetujuanPenawaran->noc->tanggal_pembayaran) ? date('Y-m-d', strtotime($persetujuanPenawaran->noc->tanggal_pembayaran)) : '') }}" {{ $hasMemo ? 'readonly' : '' }}>
|
<input type="date" name="tanggal_pembayaran" id="tanggal_pembayaran"
|
||||||
|
class="input w-full @error('tanggal_pembayaran') border-danger bg-danger-light @enderror"
|
||||||
|
value="{{ old('tanggal_pembayaran', isset($persetujuanPenawaran->noc->tanggal_pembayaran) ? date('Y-m-d', strtotime($persetujuanPenawaran->noc->tanggal_pembayaran)) : '') }}"
|
||||||
|
{{ $hasMemo ? 'readonly' : '' }}>
|
||||||
@error('tanggal_pembayaran')
|
@error('tanggal_pembayaran')
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
<em class="text-sm alert text-danger">{{ $message }}</em>
|
||||||
@enderror
|
@enderror
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex flex-wrap gap-2.5 items-baseline lg:flex-nowrap">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
Bukti KSL
|
Bukti KSL
|
||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
@if (!$hasMemo)
|
@if (!$hasMemo)
|
||||||
<input type="file" name="bukti_ksl" id="bukti_ksl" class="file-input w-full @error('bukti_ksl') border-danger bg-danger-light @enderror" accept=".pdf,.jpg,.jpeg,.png">
|
<input type="file" name="bukti_ksl" id="bukti_ksl"
|
||||||
|
class="file-input w-full @error('bukti_ksl') border-danger bg-danger-light @enderror"
|
||||||
|
accept=".pdf,.jpg,.jpeg,.png">
|
||||||
@error('bukti_ksl')
|
@error('bukti_ksl')
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
<em class="text-sm alert text-danger">{{ $message }}</em>
|
||||||
@enderror
|
@enderror
|
||||||
@endif
|
@endif
|
||||||
|
|
||||||
@if (isset($persetujuanPenawaran->noc->bukti_ksl) && !empty($persetujuanPenawaran->noc->bukti_ksl))
|
@if (isset($persetujuanPenawaran->noc->bukti_ksl) && !empty($persetujuanPenawaran->noc->bukti_ksl))
|
||||||
<div class="mt-2 flex items-center">
|
<div class="flex items-center mt-2">
|
||||||
<a href="{{ Storage::url($persetujuanPenawaran->noc->bukti_ksl) }}" target="_blank" class="badge badge-sm badge-outline badge-warning">
|
<a href="{{ Storage::url($persetujuanPenawaran->noc->bukti_ksl) }}" target="_blank"
|
||||||
<i class="ki-filled ki-eye mr-2"></i> Lihat File
|
class="badge badge-sm badge-outline badge-warning">
|
||||||
|
<i class="mr-2 ki-filled ki-eye"></i> Lihat File
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
@endif
|
@endif
|
||||||
@@ -126,86 +150,101 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
@if ($hasMemo)
|
@if ($hasMemo)
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex flex-wrap gap-2.5 items-baseline lg:flex-nowrap">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
Memo Penyelesaian
|
Memo Penyelesaian
|
||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
<div class="flex items-center">
|
<div class="flex items-center">
|
||||||
<a href="{{ Storage::url($persetujuanPenawaran->noc->memo_penyelesaian) }}" target="_blank" class="badge badge-sm badge-outline badge-warning">
|
<a href="{{ Storage::url($persetujuanPenawaran->noc->memo_penyelesaian) }}"
|
||||||
<i class="ki-filled ki-eye mr-2"></i> Lihat File
|
target="_blank" class="badge badge-sm badge-outline badge-warning">
|
||||||
|
<i class="mr-2 ki-filled ki-eye"></i> Lihat File
|
||||||
</a>
|
</a>
|
||||||
<input type="hidden" name="memo_penyelesaian_existing" value="{{ $persetujuanPenawaran->noc->memo_penyelesaian }}">
|
<input type="hidden" name="memo_penyelesaian_existing"
|
||||||
|
value="{{ $persetujuanPenawaran->noc->memo_penyelesaian }}">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex flex-wrap gap-2.5 items-baseline lg:flex-nowrap">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
Bukti Penyelesaian
|
Bukti Penyelesaian
|
||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
<input type="file" name="bukti_penyelesaian" id="bukti_penyelesaian" class="file-input w-full @error('bukti_penyelesaian') border-danger bg-danger-light @enderror" accept=".pdf,.jpg,.jpeg,.png">
|
<input type="file" name="bukti_penyelesaian" id="bukti_penyelesaian"
|
||||||
|
class="file-input w-full @error('bukti_penyelesaian') border-danger bg-danger-light @enderror"
|
||||||
|
accept=".pdf,.jpg,.jpeg,.png">
|
||||||
@error('bukti_penyelesaian')
|
@error('bukti_penyelesaian')
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
<em class="text-sm alert text-danger">{{ $message }}</em>
|
||||||
@enderror
|
@enderror
|
||||||
|
|
||||||
@if (isset($persetujuanPenawaran->noc->bukti_penyelesaian) && !empty($persetujuanPenawaran->noc->bukti_penyelesaian))
|
@if (isset($persetujuanPenawaran->noc->bukti_penyelesaian) && !empty($persetujuanPenawaran->noc->bukti_penyelesaian))
|
||||||
<div class="mt-2 flex items-center">
|
<div class="flex items-center mt-2">
|
||||||
<a href="{{ Storage::url($persetujuanPenawaran->noc->bukti_penyelesaian) }}" target="_blank" class="badge badge-sm badge-outline badge-warning">
|
<a href="{{ Storage::url($persetujuanPenawaran->noc->bukti_penyelesaian) }}"
|
||||||
<i class="ki-filled ki-eye mr-2"></i> Lihat File
|
target="_blank" class="badge badge-sm badge-outline badge-warning">
|
||||||
|
<i class="mr-2 ki-filled ki-eye"></i> Lihat File
|
||||||
</a>
|
</a>
|
||||||
<input type="hidden" name="bukti_penyelesaian_existing" value="{{ $persetujuanPenawaran->noc->bukti_penyelesaian }}">
|
<input type="hidden" name="bukti_penyelesaian_existing"
|
||||||
|
value="{{ $persetujuanPenawaran->noc->bukti_penyelesaian }}">
|
||||||
</div>
|
</div>
|
||||||
@endif
|
@endif
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex flex-wrap gap-2.5 items-baseline lg:flex-nowrap">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
Nominal Penyelesaian
|
Nominal Penyelesaian
|
||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
<input type="number" name="nominal_penyelesaian" id="nominal_penyelesaian" class="input w-full @error('nominal_penyelesaian') border-danger bg-danger-light @enderror" value="{{ old('nominal_penyelesaian', $persetujuanPenawaran->noc->nominal_penyelesaian ?? '') }}" placeholder="Masukkan nominal penyelesaian">
|
<input type="number" name="nominal_penyelesaian" id="nominal_penyelesaian"
|
||||||
|
class="input w-full @error('nominal_penyelesaian') border-danger bg-danger-light @enderror"
|
||||||
|
value="{{ old('nominal_penyelesaian', $persetujuanPenawaran->noc->nominal_penyelesaian ?? '') }}"
|
||||||
|
placeholder="Masukkan nominal penyelesaian">
|
||||||
@error('nominal_penyelesaian')
|
@error('nominal_penyelesaian')
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
<em class="text-sm alert text-danger">{{ $message }}</em>
|
||||||
@enderror
|
@enderror
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex flex-wrap gap-2.5 items-baseline lg:flex-nowrap">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
Tanggal Penyelesaian
|
Tanggal Penyelesaian
|
||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
<input type="date" name="tanggal_penyelesaian" id="tanggal_penyelesaian" class="input w-full @error('tanggal_penyelesaian') border-danger bg-danger-light @enderror" value="{{ old('tanggal_penyelesaian', isset($persetujuanPenawaran->noc->tanggal_penyelesaian) ? date('Y-m-d', strtotime($persetujuanPenawaran->noc->tanggal_penyelesaian)) : '') }}">
|
<input type="date" name="tanggal_penyelesaian" id="tanggal_penyelesaian"
|
||||||
|
class="input w-full @error('tanggal_penyelesaian') border-danger bg-danger-light @enderror"
|
||||||
|
value="{{ old('tanggal_penyelesaian', isset($persetujuanPenawaran->noc->tanggal_penyelesaian) ? date('Y-m-d', strtotime($persetujuanPenawaran->noc->tanggal_penyelesaian)) : '') }}">
|
||||||
@error('tanggal_penyelesaian')
|
@error('tanggal_penyelesaian')
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
<em class="text-sm alert text-danger">{{ $message }}</em>
|
||||||
@enderror
|
@enderror
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@endif
|
@endif
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex flex-wrap gap-2.5 items-baseline lg:flex-nowrap">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
Catatan
|
Catatan
|
||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
<textarea name="catatan" id="catatan" rows="4" class="textarea w-full @error('catatan') border-danger bg-danger-light @enderror" readonly placeholder="Masukkan catatan">{{ old('catatan', $persetujuanPenawaran->catatan ?? '') }}</textarea>
|
<textarea name="catatan" id="catatan" rows="4"
|
||||||
|
class="textarea w-full @error('catatan') border-danger bg-danger-light @enderror" readonly
|
||||||
|
placeholder="Masukkan catatan">{{ old('catatan', $persetujuanPenawaran->catatan ?? '') }}</textarea>
|
||||||
@error('catatan')
|
@error('catatan')
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
<em class="text-sm alert text-danger">{{ $message }}</em>
|
||||||
@enderror
|
@enderror
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex flex-wrap gap-2.5 items-baseline lg:flex-nowrap">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
Catatan NOC
|
Catatan NOC
|
||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
<textarea name="catatan_noc" id="catatan_noc" rows="4" class="textarea w-full @error('catatan_noc') border-danger bg-danger-light @enderror" placeholder="Masukkan catatan noc">{{ old('catatan_noc', $persetujuanPenawaran->noc->catatan_noc ?? '') }}</textarea>
|
<textarea name="catatan_noc" id="catatan_noc" rows="4"
|
||||||
|
class="textarea w-full @error('catatan_noc') border-danger bg-danger-light @enderror"
|
||||||
|
placeholder="Masukkan catatan noc">{{ old('catatan_noc', $persetujuanPenawaran->noc->catatan_noc ?? '') }}</textarea>
|
||||||
@error('catatan_noc')
|
@error('catatan_noc')
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
<em class="text-sm alert text-danger">{{ $message }}</em>
|
||||||
@enderror
|
@enderror
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -5,9 +5,10 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@section('content')
|
@section('content')
|
||||||
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
<div class="grid gap-5 mx-auto w-full lg:gap-7.5">
|
||||||
<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="noc-table" data-api-url="{{ route('noc.datatables.pembayaran') }}">
|
<div class="min-w-full border card border-agi-100 card-grid" data-datatable="false" data-datatable-page-size="10"
|
||||||
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
data-datatable-state-save="false" id="noc-table" data-api-url="{{ route('noc.datatables.pembayaran') }}">
|
||||||
|
<div class="flex-wrap py-5 card-header bg-agi-50">
|
||||||
<h3 class="card-title">
|
<h3 class="card-title">
|
||||||
Daftar NOC Pembayaran
|
Daftar NOC Pembayaran
|
||||||
</h3>
|
</h3>
|
||||||
@@ -27,7 +28,8 @@
|
|||||||
|
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<div class="scrollable-x-auto">
|
<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">
|
<table class="table text-sm font-medium text-gray-700 align-middle table-auto table-border"
|
||||||
|
data-datatable-table="true">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th class="w-14">
|
<th class="w-14">
|
||||||
@@ -75,13 +77,13 @@
|
|||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
<div
|
<div
|
||||||
class="card-footer justify-center md:justify-between flex-col md:flex-row gap-3 text-gray-600 text-2sm font-medium">
|
class="flex-col gap-3 justify-center font-medium text-gray-600 card-footer md:justify-between md:flex-row text-2sm">
|
||||||
<div class="flex items-center gap-2">
|
<div class="flex gap-2 items-center">
|
||||||
Show
|
Show
|
||||||
<select class="select select-sm w-16" data-datatable-size="true" name="perpage"> </select> per
|
<select class="w-16 select select-sm" data-datatable-size="true" name="perpage"> </select> per
|
||||||
page
|
page
|
||||||
</div>
|
</div>
|
||||||
<div class="flex items-center gap-4">
|
<div class="flex gap-4 items-center">
|
||||||
<span data-datatable-info="true"> </span>
|
<span data-datatable-info="true"> </span>
|
||||||
<div class="pagination" data-datatable-pagination="true">
|
<div class="pagination" data-datatable-pagination="true">
|
||||||
</div>
|
</div>
|
||||||
@@ -140,7 +142,7 @@
|
|||||||
title: 'Cabang',
|
title: 'Cabang',
|
||||||
},
|
},
|
||||||
tanggal_setor: {
|
tanggal_setor: {
|
||||||
title: 'Tanggal Setor',
|
title: 'Tanggal KSL',
|
||||||
},
|
},
|
||||||
nominal_bayar: {
|
nominal_bayar: {
|
||||||
title: 'Nominal Bayar',
|
title: 'Nominal Bayar',
|
||||||
|
|||||||
@@ -2,20 +2,28 @@
|
|||||||
@php
|
@php
|
||||||
use Modules\Usermanagement\Models\User;
|
use Modules\Usermanagement\Models\User;
|
||||||
|
|
||||||
$penilaiUser = User::where('id', $penilai->userPenilaiTeam->id)->first();
|
$penilaiUser = isset($penilai->userPenilaiTeam) ? $penilai->userPenilaiTeam : null;
|
||||||
$imagePathPenilai = storage_path(
|
$imagePathPenilai = $penilaiUser && $penilaiUser->sign
|
||||||
'app/public/signatures/' . $penilaiUser->id . '/' . $penilaiUser->sign,
|
? storage_path('app/public/signatures/' . $penilaiUser->id . '/' . $penilaiUser->sign)
|
||||||
);
|
: null;
|
||||||
|
|
||||||
|
$soUser = $permohonan->approval_so ? User::find($permohonan->approval_so) : null;
|
||||||
|
$imagePathSo = $soUser && $soUser->sign
|
||||||
|
? storage_path('app/public/signatures/' . $soUser->id . '/' . $soUser->sign)
|
||||||
|
: null;
|
||||||
|
|
||||||
|
$eoUser = $permohonan->approval_eo ? User::find($permohonan->approval_eo) : null;
|
||||||
|
$imagePathEO = $eoUser && $eoUser->sign
|
||||||
|
? storage_path('app/public/signatures/' . $eoUser->id . '/' . $eoUser->sign)
|
||||||
|
: null;
|
||||||
|
|
||||||
|
|
||||||
|
$ddUser = $permohonan->approval_dd ? User::find($permohonan->approval_dd) : null;
|
||||||
|
$imagePathDD = $ddUser && $ddUser->sign
|
||||||
|
? storage_path('app/public/signatures/' . $ddUser->id . '/' . $ddUser->sign)
|
||||||
|
: null;
|
||||||
|
|
||||||
$soUser = User::where('id', $senior_officer->id)->first();
|
|
||||||
$imagePathSo = storage_path('app/public/signatures/' . $soUser->id . '/' . $soUser->sign);
|
|
||||||
|
|
||||||
$imagePathEO = storage_path(
|
|
||||||
'app/public/signatures/' .
|
|
||||||
User::role('EO Appraisal')->first()->id .
|
|
||||||
'/' .
|
|
||||||
User::role('EO Appraisal')->first()->sign,
|
|
||||||
);
|
|
||||||
|
|
||||||
$imagePathDD = storage_path(
|
$imagePathDD = storage_path(
|
||||||
'app/public/signatures/' .
|
'app/public/signatures/' .
|
||||||
|
|||||||
@@ -673,6 +673,10 @@ Breadcrumbs::for('noc', function (BreadcrumbTrail $trail) {
|
|||||||
$trail->push('NOC', route('noc.index'));
|
$trail->push('NOC', route('noc.index'));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Breadcrumbs::for('noc.show', function (BreadcrumbTrail $trail) {
|
||||||
|
$trail->push('NOC', route('noc.index'));
|
||||||
|
});
|
||||||
|
|
||||||
Breadcrumbs::for('noc.pembayaran', function (BreadcrumbTrail $trail) {
|
Breadcrumbs::for('noc.pembayaran', function (BreadcrumbTrail $trail) {
|
||||||
$trail->push('NOC Pembayaran', route('noc.pembayaran.index'));
|
$trail->push('NOC Pembayaran', route('noc.pembayaran.index'));
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -748,6 +748,7 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
// laporan user
|
// laporan user
|
||||||
Route::prefix('laporan-user')->name('laporan-user.')->group(function () {
|
Route::prefix('laporan-user')->name('laporan-user.')->group(function () {
|
||||||
Route::get('/', [LaporanUserController::class, 'index'])->name('index');
|
Route::get('/', [LaporanUserController::class, 'index'])->name('index');
|
||||||
|
Route::get('export', [LaporanUserController::class, 'export'])->name('export');
|
||||||
Route::get('api/user-pemohon', [LaporanUserController::class, 'searchUserPemohon'])->name('api.user-pemohon');
|
Route::get('api/user-pemohon', [LaporanUserController::class, 'searchUserPemohon'])->name('api.user-pemohon');
|
||||||
Route::get('datatables', [LaporanUserController::class, 'dataTableForUserPemohon'])->name('datatables');
|
Route::get('datatables', [LaporanUserController::class, 'dataTableForUserPemohon'])->name('datatables');
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user