Merge pull request 'feature/senior-officer' (#91) from feature/senior-officer into staging
Reviewed-on: #91
This commit is contained in:
@@ -11,6 +11,10 @@ use Modules\Lpj\Models\JenisDokumen;
|
|||||||
use Modules\Lpj\Models\TeamsUsers;
|
use Modules\Lpj\Models\TeamsUsers;
|
||||||
use Modules\Lpj\Models\Laporan;
|
use Modules\Lpj\Models\Laporan;
|
||||||
use Modules\Usermanagement\Models\User;
|
use Modules\Usermanagement\Models\User;
|
||||||
|
use Modules\Location\Models\Province;
|
||||||
|
use Modules\Location\Models\City;
|
||||||
|
use Modules\Location\Models\District;
|
||||||
|
use Modules\Location\Models\Village;
|
||||||
|
|
||||||
function formatTanggalIndonesia($date, $time = false)
|
function formatTanggalIndonesia($date, $time = false)
|
||||||
{
|
{
|
||||||
@@ -373,3 +377,36 @@ function getCustomField($param){
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
function getWilayahName($code, $type)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$wilayah = null;
|
||||||
|
|
||||||
|
if (!$code) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch ($type) {
|
||||||
|
case 'province':
|
||||||
|
$wilayah = Province::where('code', $code)->first();
|
||||||
|
return $wilayah ? $wilayah->name : null;
|
||||||
|
|
||||||
|
case 'city':
|
||||||
|
$wilayah = City::where('code', $code)->first();
|
||||||
|
return $wilayah ? $wilayah->name : null;
|
||||||
|
|
||||||
|
case 'district':
|
||||||
|
$wilayah = District::where('code', $code)->first();
|
||||||
|
return $wilayah ? $wilayah->name : null;
|
||||||
|
|
||||||
|
case 'village':
|
||||||
|
$wilayah = Village::where('code', $code)->first();
|
||||||
|
return $wilayah ? $wilayah->name : null;
|
||||||
|
|
||||||
|
default:
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -1032,10 +1032,10 @@ class PenilaiController extends Controller
|
|||||||
|
|
||||||
$alamat = [
|
$alamat = [
|
||||||
'address' => $inputAddress['address'] ?? null,
|
'address' => $inputAddress['address'] ?? null,
|
||||||
'village_code' => $this->getWilayahName($inputAddress['village_code'] ?? null, 'village'),
|
'village_code' => getWilayahName($inputAddress['village_code'] ?? null, 'village'),
|
||||||
'district_code' => $this->getWilayahName($inputAddress['district_code'] ?? null, 'district'),
|
'district_code' => getWilayahName($inputAddress['district_code'] ?? null, 'district'),
|
||||||
'city_code' => $this->getWilayahName($inputAddress['city_code'] ?? null, 'city'),
|
'city_code' => getWilayahName($inputAddress['city_code'] ?? null, 'city'),
|
||||||
'province_code' => $this->getWilayahName($inputAddress['province_code'] ?? null, 'province')
|
'province_code' => getWilayahName($inputAddress['province_code'] ?? null, 'province')
|
||||||
];
|
];
|
||||||
|
|
||||||
$viewLaporan = $this->getViewLaporan($tipeLaporan);
|
$viewLaporan = $this->getViewLaporan($tipeLaporan);
|
||||||
@@ -1112,39 +1112,6 @@ class PenilaiController extends Controller
|
|||||||
return $viewMap[$tipe] ?? 'penilai.components.print-resume';
|
return $viewMap[$tipe] ?? 'penilai.components.print-resume';
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getWilayahName($code, $type)
|
|
||||||
{
|
|
||||||
try {
|
|
||||||
$wilayah = null;
|
|
||||||
|
|
||||||
if (!$code) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch ($type) {
|
|
||||||
case 'province':
|
|
||||||
$wilayah = Province::where('code', $code)->first();
|
|
||||||
return $wilayah ? $wilayah->name : null;
|
|
||||||
|
|
||||||
case 'city':
|
|
||||||
$wilayah = City::where('code', $code)->first();
|
|
||||||
return $wilayah ? $wilayah->name : null;
|
|
||||||
|
|
||||||
case 'district':
|
|
||||||
$wilayah = District::where('code', $code)->first();
|
|
||||||
return $wilayah ? $wilayah->name : null;
|
|
||||||
|
|
||||||
case 'village':
|
|
||||||
$wilayah = Village::where('code', $code)->first();
|
|
||||||
return $wilayah ? $wilayah->name : null;
|
|
||||||
|
|
||||||
default:
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
} catch (\Exception $e) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// mengambil data dari fungsi permohonan di surveyor, dan table
|
// mengambil data dari fungsi permohonan di surveyor, dan table
|
||||||
@@ -1322,8 +1289,7 @@ class PenilaiController extends Controller
|
|||||||
'resume' => [
|
'resume' => [
|
||||||
'fakta.fakta_positif',
|
'fakta.fakta_positif',
|
||||||
'fakta.fakta_negatif',
|
'fakta.fakta_negatif',
|
||||||
'fisik',
|
'fisik'
|
||||||
'keterangan'
|
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|||||||
@@ -80,6 +80,7 @@ use Modules\Lpj\Models\SpekBagunanAnalisaDetail;
|
|||||||
use Modules\Lpj\Http\Requests\SurveyorRequest;
|
use Modules\Lpj\Http\Requests\SurveyorRequest;
|
||||||
use Modules\Lpj\Http\Requests\FormSurveyorRequest;
|
use Modules\Lpj\Http\Requests\FormSurveyorRequest;
|
||||||
use Modules\Lpj\Emails\SendJadwalKunjunganEmail;
|
use Modules\Lpj\Emails\SendJadwalKunjunganEmail;
|
||||||
|
use App\Helpers\Lpj;
|
||||||
|
|
||||||
class SurveyorController extends Controller
|
class SurveyorController extends Controller
|
||||||
{
|
{
|
||||||
@@ -3303,6 +3304,7 @@ class SurveyorController extends Controller
|
|||||||
$validator = Validator::make($request->all(), [
|
$validator = Validator::make($request->all(), [
|
||||||
'signature' => 'required',
|
'signature' => 'required',
|
||||||
'type' => 'required|in:penilai,cabang,debitur,kjjp',
|
'type' => 'required|in:penilai,cabang,debitur,kjjp',
|
||||||
|
'name' => 'nullable|string',
|
||||||
'document_id' => 'nullable|string'
|
'document_id' => 'nullable|string'
|
||||||
]);
|
]);
|
||||||
|
|
||||||
@@ -3338,6 +3340,7 @@ class SurveyorController extends Controller
|
|||||||
// Simpan atau update signature berdasarkan type
|
// Simpan atau update signature berdasarkan type
|
||||||
$dataForm['signature'][$request->type] = [
|
$dataForm['signature'][$request->type] = [
|
||||||
'image' => $request->signature,
|
'image' => $request->signature,
|
||||||
|
'name' => $request->name,
|
||||||
'created_at' => now()->toDateTimeString(),
|
'created_at' => now()->toDateTimeString(),
|
||||||
'updated_at' => now()->toDateTimeString()
|
'updated_at' => now()->toDateTimeString()
|
||||||
];
|
];
|
||||||
@@ -3381,6 +3384,7 @@ class SurveyorController extends Controller
|
|||||||
'data' => [
|
'data' => [
|
||||||
'signature' => $dataForm['signature'][$type]['image'],
|
'signature' => $dataForm['signature'][$type]['image'],
|
||||||
'type' => $type,
|
'type' => $type,
|
||||||
|
'name' => $dataForm['signature'][$type]['name'] ?? '',
|
||||||
'created_at' => $dataForm['signature'][$type]['created_at'],
|
'created_at' => $dataForm['signature'][$type]['created_at'],
|
||||||
'updated_at' => $dataForm['signature'][$type]['updated_at']
|
'updated_at' => $dataForm['signature'][$type]['updated_at']
|
||||||
]
|
]
|
||||||
@@ -3495,6 +3499,25 @@ class SurveyorController extends Controller
|
|||||||
return redirect()->back()->with('error', 'Data inspeksi tidak ditemukan.');
|
return redirect()->back()->with('error', 'Data inspeksi tidak ditemukan.');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$forminspeksi = json_decode($inspeksi->data_form, true);
|
||||||
|
|
||||||
|
if (!$forminspeksi) {
|
||||||
|
// Redirect jika data form inspeksi kosong
|
||||||
|
return redirect()->back()->with('error', 'Silahkan isi terlebih dahulu form inspeksi.');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
$inputAddress = $forminspeksi['asset']['alamat']['sesuai'] ?? $forminspeksi['asset']['alamat']['tidak sesuai'] ?? [];
|
||||||
|
|
||||||
|
$alamat = [
|
||||||
|
'address' => $inputAddress['address'] ?? null,
|
||||||
|
'village_code' => getWilayahName($inputAddress['village_code'] ?? null, 'village'),
|
||||||
|
'district_code' => getWilayahName($inputAddress['district_code'] ?? null, 'district'),
|
||||||
|
'city_code' => getWilayahName($inputAddress['city_code'] ?? null, 'city'),
|
||||||
|
'province_code' => getWilayahName($inputAddress['province_code'] ?? null, 'province')
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
// Decode data form inspeksi
|
// Decode data form inspeksi
|
||||||
$forminspeksi = json_decode($inspeksi->data_form, true);
|
$forminspeksi = json_decode($inspeksi->data_form, true);
|
||||||
|
|
||||||
@@ -3509,7 +3532,7 @@ class SurveyorController extends Controller
|
|||||||
: 'lpj::surveyor.components.print-out.main';
|
: 'lpj::surveyor.components.print-out.main';
|
||||||
|
|
||||||
// Generate PDF
|
// Generate PDF
|
||||||
$pdf = PDF::loadView($templateView, compact('permohonan', 'basicData', 'forminspeksi'));
|
$pdf = PDF::loadView($templateView, compact('permohonan', 'basicData', 'forminspeksi','alamat'));
|
||||||
$pdf->setPaper('A4', 'portrait');
|
$pdf->setPaper('A4', 'portrait');
|
||||||
|
|
||||||
// Tentukan nama file PDF
|
// Tentukan nama file PDF
|
||||||
|
|||||||
@@ -525,13 +525,6 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
@include('lpj::component.detail-jaminan', ['status' => true])
|
@include('lpj::component.detail-jaminan', ['status' => true])
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5 w-full">
|
|
||||||
<label class="form-label font-medium max-w-56">Nomor NIB</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input type="text" name="nomor_nib" class="input w-full"
|
|
||||||
value="{{ $forminspeksi['asset']['nomor_nib'] ?? '' }}" placeholder="Masukkan Nomor NIB">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|||||||
@@ -1,19 +1,38 @@
|
|||||||
<!-- resources/views/signatures/components/signature-pad.blade.php -->
|
<div class="signature-pad-container mx-auto border p-4 max-w-md sm:max-w-lg lg:max-w-xl">
|
||||||
<div class="text-center border">
|
<h3 class="signature-title text-lg sm:text-xl font-semibold mb-2">{{ ucfirst($type) }}</h3>
|
||||||
<h3 class="signature-title">{{ ucfirst($type) }}</h3>
|
<canvas
|
||||||
@if (($type === 'penilai' && Auth::user()->sign))
|
id="signature-pad-{{ $type }}"
|
||||||
|
class="signature-pad w-full h-48 sm:h-56 bg-white border rounded"
|
||||||
<img src="{{ $type === 'penilai'
|
></canvas>
|
||||||
? asset('storage/signatures/' . Auth::user()->id . '/' . Auth::user()->sign)
|
<input
|
||||||
: asset('storage/signatures/' . $user->id . '/' . $user->sign) }}"
|
type="text"
|
||||||
alt="E-Sign" class="signature-pad" style="width: 400px; height: 220px;">
|
class="input w-full border p-2 mt-2 rounded"
|
||||||
@else
|
name="name-{{ $type }}"
|
||||||
<canvas id="signature-pad-{{ $type }}" class="signature-pad" width="400" height="200"></canvas>
|
id="name-{{ $type }}"
|
||||||
<div class="button-container py-2">
|
placeholder="Enter your name"
|
||||||
<button type="button" id="save-{{ $type }}" class="btn btn-xs btn-primary">Save</button>
|
/>
|
||||||
<button type="button" id="clear-{{ $type }}" class="btn btn-xs btn-secondary">Clear</button>
|
<div class="button-container flex justify-between py-4">
|
||||||
<button type="button" id="delete-{{$type}}" class="btn btn-xs btn-danger">Delete</button>
|
<button
|
||||||
|
type="button"
|
||||||
|
id="save-{{ $type }}"
|
||||||
|
class="btn btn-primary px-4 py-2 rounded "
|
||||||
|
>
|
||||||
|
Save
|
||||||
|
</button>
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
id="clear-{{ $type }}"
|
||||||
|
class="btn btn-light px-4 py-2 rounded"
|
||||||
|
>
|
||||||
|
Clear
|
||||||
|
</button>
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
id="delete-{{ $type }}"
|
||||||
|
class="btn btn-danger text-white px-4 py-2 rounded hover:bg-red-600"
|
||||||
|
>
|
||||||
|
Delete
|
||||||
|
</button>
|
||||||
</div>
|
</div>
|
||||||
<div id="status-{{ $type }}" class="status-message"></div>
|
<div id="status-{{ $type }}" class="status-message text-sm text-gray-600 mt-2"></div>
|
||||||
@endif
|
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -1,13 +1,13 @@
|
|||||||
@include('lpj::penilai.components.header')
|
@include('lpj::penilai.components.header')
|
||||||
@php
|
@php
|
||||||
$data = '';
|
$data = '';
|
||||||
foreach ($permohonan->documents as $dokumen) {
|
foreach ($permohonan->documents as $dokumen) {
|
||||||
$data .= $dokumen->jenisJaminan->name . ', ';
|
$data .= $dokumen->jenisJaminan->name . ', ';
|
||||||
}
|
}
|
||||||
$data = rtrim($data, ', ');
|
$data = rtrim($data, ', ');
|
||||||
@endphp
|
@endphp
|
||||||
|
|
||||||
<main class="content">
|
<main class="content">
|
||||||
<table style="width: 100%">
|
<table style="width: 100%">
|
||||||
<tr>
|
<tr>
|
||||||
<td style="vertical-align: top;">
|
<td style="vertical-align: top;">
|
||||||
@@ -28,7 +28,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Permintaan Cabang</td>
|
<td style="padding: 2px; vertical-align: top;">Permintaan Cabang</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">{{ $permohonan->debiture->branch->name ?? '' }}</td>
|
<td style="padding: 2px; vertical-align: top;">{{ $permohonan->debiture->branch->name ?? '' }}
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Permintaan (AO)</td>
|
<td style="padding: 2px; vertical-align: top;">Permintaan (AO)</td>
|
||||||
@@ -43,7 +44,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Tanggal Order</td>
|
<td style="padding: 2px; vertical-align: top;">Tanggal Order</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">{{ formatTanggalIndonesia($permohonan->created_at) }}</td>
|
<td style="padding: 2px; vertical-align: top;">
|
||||||
|
{{ formatTanggalIndonesia($permohonan->created_at) }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Tanggal Survey</td>
|
<td style="padding: 2px; vertical-align: top;">Tanggal Survey</td>
|
||||||
@@ -105,7 +107,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Tanggal Laporan</td>
|
<td style="padding: 2px; vertical-align: top;">Tanggal Laporan</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">{{ formatTanggalIndonesia($tanggalLaporan) ?? '' }}</td>
|
<td style="padding: 2px; vertical-align: top;">
|
||||||
|
{{ formatTanggalIndonesia($tanggalLaporan) ?? '' }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Waktu Penyelesaian</td>
|
<td style="padding: 2px; vertical-align: top;">Waktu Penyelesaian</td>
|
||||||
@@ -120,7 +123,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td style=" padding: 2px; vertical-align: top;">Fasilitas Kredit</td>
|
<td style=" padding: 2px; vertical-align: top;">Fasilitas Kredit</td>
|
||||||
<td style=" padding: 2px; vertical-align: top;">:</td>
|
<td style=" padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style=" padding: 2px; vertical-align: top;">{{ $permohonan->jenisFasilitasKredit->name ?? '' }}</td>
|
<td style=" padding: 2px; vertical-align: top;">
|
||||||
|
{{ $permohonan->jenisFasilitasKredit->name ?? '' }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
|
|
||||||
@@ -131,7 +135,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td style=" padding: 2px; vertical-align: top;">Tujuan Penilaian</td>
|
<td style=" padding: 2px; vertical-align: top;">Tujuan Penilaian</td>
|
||||||
<td style=" padding: 2px; vertical-align: top;">:</td>
|
<td style=" padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style=" padding: 2px; vertical-align: top;">{{ $permohonan->tujuanPenilaian->name ?? '' }}</td>
|
<td style=" padding: 2px; vertical-align: top;">{{ $permohonan->tujuanPenilaian->name ?? '' }}
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td style=" padding: 2px; vertical-align: top;">Terletak di</td>
|
<td style=" padding: 2px; vertical-align: top;">Terletak di</td>
|
||||||
@@ -217,7 +222,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td style=" padding: 2px; vertical-align: top;">Nomor NIB</td>
|
<td style=" padding: 2px; vertical-align: top;">Nomor NIB</td>
|
||||||
<td style=" padding: 2px; vertical-align: top;">:</td>
|
<td style=" padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style=" padding: 2px; vertical-align: top;">{{ $forminspeksi['asset']['nomor_nib'] ?? '' }}</td>
|
<td style=" padding: 2px; vertical-align: top;">
|
||||||
|
{{ $forminspeksi['asset']['nomor_nib'] ?? '' }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
@endif
|
@endif
|
||||||
<tr>
|
<tr>
|
||||||
@@ -304,9 +310,7 @@
|
|||||||
<table>
|
<table>
|
||||||
<tr>
|
<tr>
|
||||||
@php
|
@php
|
||||||
$cekLuas = isset(
|
$cekLuas = isset($forminspeksi['tanah']['luas_tanah']['tidak sesuai'])
|
||||||
$forminspeksi['tanah']['luas_tanah']['tidak sesuai'],
|
|
||||||
)
|
|
||||||
? 'tidak sesuai'
|
? 'tidak sesuai'
|
||||||
: 'sesuai';
|
: 'sesuai';
|
||||||
|
|
||||||
@@ -326,16 +330,14 @@
|
|||||||
)
|
)
|
||||||
? $forminspeksi['tanah']['bentuk_tanah']['bentuk_tanah']
|
? $forminspeksi['tanah']['bentuk_tanah']['bentuk_tanah']
|
||||||
: [];
|
: [];
|
||||||
$lainnya = isset(
|
$lainnya = isset($forminspeksi['tanah']['bentuk_tanah']['lainnya'])
|
||||||
$forminspeksi['tanah']['bentuk_tanah']['lainnya'],
|
|
||||||
)
|
|
||||||
? $forminspeksi['tanah']['bentuk_tanah']['lainnya']
|
? $forminspeksi['tanah']['bentuk_tanah']['lainnya']
|
||||||
: null;
|
: null;
|
||||||
@endphp
|
@endphp
|
||||||
|
|
||||||
{{ !empty($bentukTanah) ? implode(', ', $bentukTanah) : 'Data tidak tersedia' }}
|
{{ !empty($bentukTanah) ? implode(', ', $bentukTanah) : '' }}
|
||||||
|
|
||||||
@if (in_array('Lainnya', $bentukTanah) && $lainnya)
|
@if (in_array('lainnya', array_map('strtolower', $bentukTanah)) && !empty($lainnya))
|
||||||
({{ $lainnya }})
|
({{ $lainnya }})
|
||||||
@endif
|
@endif
|
||||||
</td>
|
</td>
|
||||||
@@ -379,7 +381,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Peruntukan Tanah</td>
|
<td style="padding: 2px; vertical-align: top;">Peruntukan Tanah</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">Perumahan bukan Real Estate</td>
|
<td style="padding: 2px; vertical-align: top;">Perumahan bukan Real Estate
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Fisik Tanah</td>
|
<td style="padding: 2px; vertical-align: top;">Fisik Tanah</td>
|
||||||
@@ -391,13 +394,15 @@
|
|||||||
'kondisi_fisik_tanah'
|
'kondisi_fisik_tanah'
|
||||||
][0] ?? '-';
|
][0] ?? '-';
|
||||||
$lainnya =
|
$lainnya =
|
||||||
$forminspeksi['tanah']['kondisi_fisik_tanah']['lainnya'];
|
$forminspeksi['tanah']['kondisi_fisik_tanah']['lainnya'] ??
|
||||||
|
null;
|
||||||
@endphp
|
@endphp
|
||||||
|
|
||||||
{{ $kondisiFisikTanah }}
|
{{ $kondisiFisikTanah }}
|
||||||
@if ($kondisiFisikTanah === 'Lainnya' && $lainnya)
|
@if (strcasecmp($kondisiFisikTanah, 'Lainnya') === 0 && $lainnya)
|
||||||
({{ $lainnya }})
|
({{ $lainnya }})
|
||||||
@endif
|
@endif
|
||||||
|
|
||||||
</td>
|
</td>
|
||||||
|
|
||||||
</tr>
|
</tr>
|
||||||
@@ -425,8 +430,7 @@
|
|||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">
|
<td style="padding: 2px; vertical-align: top;">
|
||||||
@php
|
@php
|
||||||
$jenisBangunan =
|
$jenisBangunan = $forminspeksi['bangunan']['jenis_bangunan'] ?? [];
|
||||||
$forminspeksi['bangunan']['jenis_bangunan'] ?? [];
|
|
||||||
@endphp
|
@endphp
|
||||||
|
|
||||||
@if (!empty($jenisBangunan))
|
@if (!empty($jenisBangunan))
|
||||||
@@ -505,7 +509,8 @@
|
|||||||
@foreach ($spekKategori as $kategori => $nilaiKategori)
|
@foreach ($spekKategori as $kategori => $nilaiKategori)
|
||||||
@if (!empty($nilaiKategori))
|
@if (!empty($nilaiKategori))
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">{{ $kategori }}</td>
|
<td style="padding: 2px; vertical-align: top;">
|
||||||
|
{{ $kategori }}</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">
|
<td style="padding: 2px; vertical-align: top;">
|
||||||
{{ implode(', ', $nilaiKategori) }}</td>
|
{{ implode(', ', $nilaiKategori) }}</td>
|
||||||
@@ -515,7 +520,8 @@
|
|||||||
@endforeach
|
@endforeach
|
||||||
@else
|
@else
|
||||||
<tr>
|
<tr>
|
||||||
<td colspan="3" style="padding: 2px; vertical-align: top;">Tidak ada data
|
<td colspan="3" style="padding: 2px; vertical-align: top;">Tidak
|
||||||
|
ada data
|
||||||
spesifikasi bangunan</td>
|
spesifikasi bangunan</td>
|
||||||
</tr>
|
</tr>
|
||||||
@endif
|
@endif
|
||||||
@@ -613,12 +619,14 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Jarak Jalan Utama</td>
|
<td style="padding: 2px; vertical-align: top;">Jarak Jalan Utama</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">{{ $lingkungan['jarak_jalan_utama'] ?? '-' }} m</td>
|
<td style="padding: 2px; vertical-align: top;">{{ $lingkungan['jarak_jalan_utama'] ?? '-' }} m
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Jalan Lingkungan</td>
|
<td style="padding: 2px; vertical-align: top;">Jalan Lingkungan</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">{{ $lingkungan['jalan_linkungan'] ?? '-' }} m</td>
|
<td style="padding: 2px; vertical-align: top;">{{ $lingkungan['jalan_linkungan'] ?? '-' }} m
|
||||||
|
</td>
|
||||||
|
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Jarak CBD</td>
|
<td style="padding: 2px; vertical-align: top;">Jarak CBD</td>
|
||||||
@@ -629,7 +637,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Lebar Perkerasan Jalan</td>
|
<td style="padding: 2px; vertical-align: top;">Lebar Perkerasan Jalan</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">{{ $lingkungan['lebar_perkerasan_jalan'] ?? '-' }} m</td>
|
<td style="padding: 2px; vertical-align: top;">
|
||||||
|
{{ $lingkungan['lebar_perkerasan_jalan'] ?? '-' }} m</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Perkerasan Jalan</td>
|
<td style="padding: 2px; vertical-align: top;">Perkerasan Jalan</td>
|
||||||
@@ -643,18 +652,21 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Lalu Lintas</td>
|
<td style="padding: 2px; vertical-align: top;">Lalu Lintas</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">{{ implode(', ', $lingkungan['lalu_lintas'] ?? ['-']) }}</td>
|
<td style="padding: 2px; vertical-align: top;">
|
||||||
|
{{ implode(', ', $lingkungan['lalu_lintas'] ?? ['-']) }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Golongan Masyarakat Sekitar</td>
|
<td style="padding: 2px; vertical-align: top;">Golongan Masyarakat Sekitar</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">{{ implode(', ', $lingkungan['gol_mas_sekitar'] ?? ['-']) }}
|
<td style="padding: 2px; vertical-align: top;">
|
||||||
|
{{ implode(', ', $lingkungan['gol_mas_sekitar'] ?? ['-']) }}
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Tingkat Keramaian</td>
|
<td style="padding: 2px; vertical-align: top;">Tingkat Keramaian</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">{{ implode(', ', $lingkungan['tingkat_keramaian'] ?? ['-']) }}
|
<td style="padding: 2px; vertical-align: top;">
|
||||||
|
{{ implode(', ', $lingkungan['tingkat_keramaian'] ?? ['-']) }}
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
@@ -667,20 +679,23 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Kondisi Bangunan Sekitar</td>
|
<td style="padding: 2px; vertical-align: top;">Kondisi Bangunan Sekitar</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">{{ $lingkungan['kondisi_bagunan_disekitar_lokasi'] ?? '-' }}
|
<td style="padding: 2px; vertical-align: top;">
|
||||||
|
{{ $lingkungan['kondisi_bagunan_disekitar_lokasi'] ?? '-' }}
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Sifat Bangunan Sekitar</td>
|
<td style="padding: 2px; vertical-align: top;">Sifat Bangunan Sekitar</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">{{ $lingkungan['sifat_bagunan_disekitar_lokasi'] ?? '-' }}</td>
|
<td style="padding: 2px; vertical-align: top;">
|
||||||
|
{{ $lingkungan['sifat_bagunan_disekitar_lokasi'] ?? '-' }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
@if ($lingkungan['dekat_makam'] == 'ya')
|
@if ($lingkungan['dekat_makam'] == 'ya')
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Dekat Makam</td>
|
<td style="padding: 2px; vertical-align: top;">Dekat Makam</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">Ya, Jarak {{ $lingkungan['jarak_makam'] ?? '-' }} m
|
<td style="padding: 2px; vertical-align: top;">Ya, Jarak
|
||||||
|
{{ $lingkungan['jarak_makam'] ?? '-' }} m
|
||||||
({{ $lingkungan['nama_makam'] ?? '-' }})
|
({{ $lingkungan['nama_makam'] ?? '-' }})
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
@@ -690,7 +705,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Dekat TPS</td>
|
<td style="padding: 2px; vertical-align: top;">Dekat TPS</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">Ya, Jarak {{ $lingkungan['jarak_tps'] ?? '-' }} m
|
<td style="padding: 2px; vertical-align: top;">Ya, Jarak
|
||||||
|
{{ $lingkungan['jarak_tps'] ?? '-' }} m
|
||||||
({{ $lingkungan['nama_tps'] ?? '-' }})</td>
|
({{ $lingkungan['nama_tps'] ?? '-' }})</td>
|
||||||
</tr>
|
</tr>
|
||||||
@endif
|
@endif
|
||||||
@@ -698,7 +714,8 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 2px; vertical-align: top;">Daerah</td>
|
<td style="padding: 2px; vertical-align: top;">Daerah</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">:</td>
|
<td style="padding: 2px; vertical-align: top;">:</td>
|
||||||
<td style="padding: 2px; vertical-align: top;">{{ implode(', ', $lingkungan['merupakan_daerah'] ?? ['-']) }}
|
<td style="padding: 2px; vertical-align: top;">
|
||||||
|
{{ implode(', ', $lingkungan['merupakan_daerah'] ?? ['-']) }}
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
@@ -732,7 +749,8 @@
|
|||||||
</tr>
|
</tr>
|
||||||
@if (!empty($lpjData['asuransi_luas_bangunan']))
|
@if (!empty($lpjData['asuransi_luas_bangunan']))
|
||||||
<tr>
|
<tr>
|
||||||
<td><table border="1" style="width: 100%; border-collapse: collapse; margin-bottom: 10px;">
|
<td>
|
||||||
|
<table border="1" style="width: 100%; border-collapse: collapse; margin-bottom: 10px;">
|
||||||
<tr>
|
<tr>
|
||||||
|
|
||||||
<td style="border: 1px solid #000; padding: 4px;">Luas Bangunan</td>
|
<td style="border: 1px solid #000; padding: 4px;">Luas Bangunan</td>
|
||||||
@@ -741,10 +759,13 @@
|
|||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
<tr>
|
<tr>
|
||||||
<td style="border: 1px solid #000; padding: 4px;">{{ $lpjData['asuransi_luas_bangunan'] ?? '' }}</td>
|
<td style="border: 1px solid #000; padding: 4px;">
|
||||||
|
{{ $lpjData['asuransi_luas_bangunan'] ?? '' }}</td>
|
||||||
|
|
||||||
<td style="border: 1px solid #000; padding: 4px;">{{ formatRupiah($lpjData['asuransi_nilai_1']) ?? '' }}</td>
|
<td style="border: 1px solid #000; padding: 4px;">
|
||||||
<td style="border: 1px solid #000; padding: 4px;">{{ formatRupiah($lpjData['asuransi_nilai_2']) ?? '' }}</td>
|
{{ formatRupiah($lpjData['asuransi_nilai_1']) ?? '' }}</td>
|
||||||
|
<td style="border: 1px solid #000; padding: 4px;">
|
||||||
|
{{ formatRupiah($lpjData['asuransi_nilai_2']) ?? '' }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
</table>
|
</table>
|
||||||
@@ -998,7 +1019,8 @@
|
|||||||
|
|
||||||
@if (!empty($forminspeksi['fakta']['keterangan']))
|
@if (!empty($forminspeksi['fakta']['keterangan']))
|
||||||
<tr>
|
<tr>
|
||||||
<td width="25%" style="vertical-align: top;"><strong>Catatan yang Perlu Diperhatikan</strong></td>
|
<td width="25%" style="vertical-align: top;"><strong>Catatan yang Perlu
|
||||||
|
Diperhatikan</strong></td>
|
||||||
<td>
|
<td>
|
||||||
@php
|
@php
|
||||||
$keterangan = $forminspeksi['fakta']['keterangan'] ?? '';
|
$keterangan = $forminspeksi['fakta']['keterangan'] ?? '';
|
||||||
@@ -1177,7 +1199,8 @@
|
|||||||
}
|
}
|
||||||
// Filter fotoTypes untuk memastikan hanya yang memiliki imagePath valid
|
// Filter fotoTypes untuk memastikan hanya yang memiliki imagePath valid
|
||||||
$validPhotoTypes = array_filter($fotoTypes, function ($type) use ($forminspeksi) {
|
$validPhotoTypes = array_filter($fotoTypes, function ($type) use ($forminspeksi) {
|
||||||
return isset($forminspeksi[$type]) && file_exists(storage_path('app/public/' . $forminspeksi[$type]));
|
return isset($forminspeksi[$type]) &&
|
||||||
|
file_exists(storage_path('app/public/' . $forminspeksi[$type]));
|
||||||
});
|
});
|
||||||
@endphp
|
@endphp
|
||||||
|
|
||||||
@@ -1188,13 +1211,15 @@
|
|||||||
$type = reset($validPhotoTypes);
|
$type = reset($validPhotoTypes);
|
||||||
$imagePath = $forminspeksi[$type] ?? null;
|
$imagePath = $forminspeksi[$type] ?? null;
|
||||||
@endphp
|
@endphp
|
||||||
<td style="width: 100%; vertical-align: top; text-align: center" colspan="2" class="photo-item border">
|
<td style="width: 100%; vertical-align: top; text-align: center" colspan="2"
|
||||||
|
class="photo-item border">
|
||||||
<p style="margin: 0; font-size: 10px; text-align: center;">
|
<p style="margin: 0; font-size: 10px; text-align: center;">
|
||||||
{{ Str::title(str_replace('_', ' ', $type)) }}
|
{{ Str::title(str_replace('_', ' ', $type)) }}
|
||||||
</p>
|
</p>
|
||||||
@if ($imagePath)
|
@if ($imagePath)
|
||||||
<img src="{{ storage_path('app/public/' . $imagePath) }}" alt="{{ $imagePath }}"
|
<img src="{{ storage_path('app/public/' . $imagePath) }}"
|
||||||
class="photo-image" style="width: 100%; max-width: 300px;">
|
alt="{{ $imagePath }}" class="photo-image"
|
||||||
|
style="width: 100%; max-width: 300px;">
|
||||||
@endif
|
@endif
|
||||||
</td>
|
</td>
|
||||||
@else
|
@else
|
||||||
@@ -1208,8 +1233,9 @@
|
|||||||
{{ Str::title(str_replace('_', ' ', $type)) }}
|
{{ Str::title(str_replace('_', ' ', $type)) }}
|
||||||
</p>
|
</p>
|
||||||
@if ($imagePath && file_exists(storage_path('app/public/' . $imagePath)))
|
@if ($imagePath && file_exists(storage_path('app/public/' . $imagePath)))
|
||||||
<img src="{{ storage_path('app/public/' . $imagePath) }}" alt="{{ $imagePath }}"
|
<img src="{{ storage_path('app/public/' . $imagePath) }}"
|
||||||
class="photo-image" style="width: 100%; max-width: 300px;">
|
alt="{{ $imagePath }}" class="photo-image"
|
||||||
|
style="width: 100%; max-width: 300px;">
|
||||||
@endif
|
@endif
|
||||||
</td>
|
</td>
|
||||||
@endisset
|
@endisset
|
||||||
@@ -1240,5 +1266,5 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</main>
|
</main>
|
||||||
@include('lpj::penilai.components.footer')
|
@include('lpj::penilai.components.footer')
|
||||||
|
|||||||
@@ -206,24 +206,21 @@
|
|||||||
<i class="ki-outline ki-abstract-33"></i> Camera
|
<i class="ki-outline ki-abstract-33"></i> Camera
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@if ($forminspeksi)
|
|
||||||
@php
|
@php
|
||||||
$fotoTempat = $forminspeksi['foto_tempat'] ?? null;
|
$fotoTempat = $forminspeksi['foto_tempat'] ?? null;
|
||||||
|
$fotoSrc = '';
|
||||||
|
|
||||||
|
if (is_array($fotoTempat)) {
|
||||||
|
$fotoSrc = asset('storage/' . $fotoTempat[0]);
|
||||||
|
} elseif (!empty($fotoTempat)) {
|
||||||
|
$fotoSrc = asset('storage/' . $fotoTempat);
|
||||||
|
}
|
||||||
@endphp
|
@endphp
|
||||||
|
|
||||||
@if (is_array($fotoTempat) && count($fotoTempat) > 0)
|
<img id="foto_tempat-preview" src="{{ $fotoSrc ?: asset('images/default-placeholder.png') }}"
|
||||||
<img id="foto_tempat-preview"
|
|
||||||
src="{{ isset($forminspeksi['foto_tempat']) ? asset('storage/' . (is_array($forminspeksi['foto_tempat']) ? $forminspeksi['foto_tempat'][0] : $forminspeksi['foto_tempat'])) : '' }}"
|
|
||||||
alt="Foto Tempat" class="mt-2 max-w-full h-auto"
|
alt="Foto Tempat" class="mt-2 max-w-full h-auto"
|
||||||
style="{{ isset($forminspeksi['foto_tempat']) ? '' : 'display: none;' }}
|
style="max-width: 30rem; {{ $fotoSrc ? '' : 'display: none;' }}">
|
||||||
@else
|
|
||||||
<img id="foto_tempat-preview"
|
|
||||||
src="{{ asset('storage/' . (isset($forminspeksi['foto_tempat']) ? $forminspeksi['foto_tempat'] : '')) }}"
|
|
||||||
alt="Foto Tempat" class="mt-2 max-w-full h-auto"
|
|
||||||
style="{{ isset($forminspeksi['foto_tempat']) ? '' : 'display: none;' }} max-width: 30rem;">
|
|
||||||
@endif
|
|
||||||
@endif
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|||||||
@@ -60,6 +60,9 @@
|
|||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="card-footer">
|
||||||
|
<span class="text-sm text-danger">* Harap Menyimpan tanda tangan terlebih dahulu</span>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="flex justify-end gap-2" style="margin-right: 20px; margin-top: 20px">
|
<div class="flex justify-end gap-2" style="margin-right: 20px; margin-top: 20px">
|
||||||
@@ -67,8 +70,6 @@
|
|||||||
<i class="ki-filled ki-save-2"></i>
|
<i class="ki-filled ki-save-2"></i>
|
||||||
<span id="saveButtonText">Save</span>
|
<span id="saveButtonText">Save</span>
|
||||||
</button>
|
</button>
|
||||||
<a href="{{ route('surveyor.print_out_inspeksi', ['permohonan_id' => $permohonan->id, 'dokument_id' => request('dokument'), 'jenis_jaminan_id' => request('jenis_jaminan')]) }}"
|
|
||||||
class="btn btn-info" id="saveButton">
|
|
||||||
<a href="{{ route('surveyor.print_out_inspeksi', ['permohonan_id' => $permohonan->id, 'dokument_id' => request('dokument'), 'jenis_jaminan_id' => request('jenis_jaminan')]) }}"
|
<a href="{{ route('surveyor.print_out_inspeksi', ['permohonan_id' => $permohonan->id, 'dokument_id' => request('dokument'), 'jenis_jaminan_id' => request('jenis_jaminan')]) }}"
|
||||||
class="btn btn-info" id="saveButton">
|
class="btn btn-info" id="saveButton">
|
||||||
<i class="ki-filled ki-printer"></i>
|
<i class="ki-filled ki-printer"></i>
|
||||||
@@ -78,6 +79,13 @@
|
|||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
|
@php
|
||||||
|
use Modules\Usermanagement\Models\User;
|
||||||
|
$cabangUser = User::where('id', $permohonan->user->id)->first();
|
||||||
|
|
||||||
|
// print_r($cabangUser->sign);
|
||||||
|
|
||||||
|
@endphp
|
||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
@@ -85,54 +93,91 @@
|
|||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
const datas = @json($forminspeksi ?? '');
|
const datas = @json($forminspeksi ?? '');
|
||||||
console.log(datas);
|
console.log(datas);
|
||||||
|
|
||||||
document.addEventListener('DOMContentLoaded', function() {
|
document.addEventListener('DOMContentLoaded', function() {
|
||||||
const signaturePads = {};
|
const signaturePads = {};
|
||||||
const types = ['penilai', 'cabang', 'debitur', 'kjjp'];
|
const types = ['penilai', 'cabang', 'debitur', 'kjjp'];
|
||||||
|
|
||||||
// Inisialisasi semua signature pad
|
// Inisialisasi semua signature pad
|
||||||
types.forEach(type => {
|
types.forEach(type => initSignaturePad(type));
|
||||||
initSignaturePad(type);
|
|
||||||
});
|
|
||||||
|
|
||||||
function initSignaturePad(type) {
|
function initSignaturePad(type) {
|
||||||
const canvas = document.getElementById(`signature-pad-${type}`);
|
const canvas = document.getElementById(`signature-pad-${type}`);
|
||||||
if (!canvas) return;
|
if (!canvas) return;
|
||||||
|
|
||||||
// Set ukuran canvas yang responsif
|
setCanvasSize(canvas);
|
||||||
canvas.width = canvas.offsetWidth;
|
|
||||||
canvas.height = canvas.offsetHeight;
|
|
||||||
|
|
||||||
signaturePads[type] = new SignaturePad(canvas, {
|
const signaturePad = new SignaturePad(canvas, {
|
||||||
backgroundColor: 'rgba(255, 255, 255, 0)',
|
backgroundColor: 'rgba(255, 255, 255, 0)',
|
||||||
penColor: 'rgb(0, 0, 0)',
|
penColor: 'rgb(0, 0, 0)',
|
||||||
minWidth: 0.5,
|
minWidth: 0.5,
|
||||||
maxWidth: 2.5
|
maxWidth: 2.5
|
||||||
});
|
});
|
||||||
|
signaturePads[type] = signaturePad;
|
||||||
|
|
||||||
// Load existing signature
|
// Load tanda tangan yang ada
|
||||||
loadSignature(type);
|
if (type === 'penilai' || type === 'cabang') {
|
||||||
|
loadPenilaiAndCabangSignature(type, signaturePad);
|
||||||
|
} else {
|
||||||
|
loadSignature(type, signaturePad);
|
||||||
|
}
|
||||||
|
|
||||||
// Event listeners
|
// Event listeners
|
||||||
const saveBtn = document.getElementById(`save-${type}`);
|
addEventListeners(type, signaturePad);
|
||||||
const clearBtn = document.getElementById(`clear-${type}`);
|
|
||||||
const deleteBtn = document.getElementById(`delete-${type}`);
|
|
||||||
|
|
||||||
if (saveBtn) {
|
|
||||||
saveBtn.addEventListener('click', () => saveSignature(type));
|
|
||||||
}
|
|
||||||
if (clearBtn) {
|
|
||||||
clearBtn.addEventListener('click', () => clearSignature(type));
|
|
||||||
}
|
|
||||||
if (deleteBtn) {
|
|
||||||
deleteBtn.addEventListener('click', () => deleteSignature(type));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function saveSignature(type) {
|
function setCanvasSize(canvas) {
|
||||||
const signaturePad = signaturePads[type];
|
const ratio = Math.max(window.devicePixelRatio || 1, 1);
|
||||||
|
canvas.width = canvas.offsetWidth * ratio;
|
||||||
|
canvas.height = canvas.offsetHeight * ratio;
|
||||||
|
canvas.getContext('2d').scale(ratio, ratio);
|
||||||
|
}
|
||||||
|
|
||||||
if (!signaturePad || signaturePad.isEmpty()) {
|
function addEventListeners(type, signaturePad) {
|
||||||
|
document.getElementById(`save-${type}`)?.addEventListener('click', () => saveSignature(type,
|
||||||
|
signaturePad));
|
||||||
|
document.getElementById(`clear-${type}`)?.addEventListener('click', () => clearSignature(
|
||||||
|
signaturePad));
|
||||||
|
document.getElementById(`delete-${type}`)?.addEventListener('click', () => deleteSignature(type,
|
||||||
|
signaturePad));
|
||||||
|
}
|
||||||
|
|
||||||
|
function loadPenilaiAndCabangSignature(type, signaturePad) {
|
||||||
|
const nameInputElement = document.getElementById(`name-${type}`);
|
||||||
|
|
||||||
|
const params = new URLSearchParams({
|
||||||
|
document_id: document.getElementById('dokument_id')?.value,
|
||||||
|
permohonan_id: document.getElementById('permohonan_id')?.value
|
||||||
|
});
|
||||||
|
|
||||||
|
fetch(`{{ url('/surveyor/signatures/${type}') }}?${params}`)
|
||||||
|
.then(response => response.json())
|
||||||
|
.then(data => {
|
||||||
|
if (data.success && data.data?.signature) {
|
||||||
|
drawSignature(signaturePad, data.data.signature);
|
||||||
|
if (nameInputElement) {
|
||||||
|
nameInputElement.value = data.data.name || '';
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
const signUrl = type === 'penilai' ?
|
||||||
|
`{{ asset('storage/signatures/' . Auth::user()->id . '/' . Auth::user()->sign) }}` :
|
||||||
|
`{{ asset('storage/signatures/' . $cabangUser->id . '/' . $cabangUser->sign) }}`;
|
||||||
|
|
||||||
|
drawSignature(signaturePad, signUrl);
|
||||||
|
|
||||||
|
const defaultName = type === 'penilai' ?
|
||||||
|
`{{ Auth::user()->name }}` :
|
||||||
|
`{{ $cabangUser->name }}`;
|
||||||
|
if (nameInputElement) {
|
||||||
|
nameInputElement.value = defaultName;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.catch(error => console.error(`Error loading ${type} signature:`, error));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function saveSignature(type, signaturePad) {
|
||||||
|
if (signaturePad.isEmpty() && type !== 'penilai' && type !== 'cabang') {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
icon: 'warning',
|
icon: 'warning',
|
||||||
title: 'Peringatan',
|
title: 'Peringatan',
|
||||||
@@ -141,22 +186,26 @@
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const signatureDataUrl = signaturePad.isEmpty()
|
||||||
|
? (type === 'penilai'
|
||||||
|
? `{{ asset('storage/signatures/' . Auth::user()->id . '/' . Auth::user()->sign) }}`
|
||||||
|
: (type === 'cabang'
|
||||||
|
? `{{ asset('storage/signatures/' . $cabangUser->id . '/' . $cabangUser->sign) }}`
|
||||||
|
: ''))
|
||||||
|
: signaturePad.toDataURL('image/png');
|
||||||
|
|
||||||
const data = {
|
const data = {
|
||||||
signature: signaturePad.toDataURL('image/png'),
|
signature: signatureDataUrl,
|
||||||
type: type,
|
type: type,
|
||||||
|
name: document.getElementById(`name-${type}`)?.value,
|
||||||
document_id: document.getElementById('dokument_id')?.value,
|
document_id: document.getElementById('dokument_id')?.value,
|
||||||
permohonan_id: document.getElementById('permohonan_id')?.value
|
permohonan_id: document.getElementById('permohonan_id')?.value
|
||||||
};
|
};
|
||||||
console.log(data);
|
|
||||||
|
|
||||||
|
|
||||||
// Tampilkan loading
|
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
title: 'Menyimpan...',
|
title: 'Menyimpan...',
|
||||||
allowOutsideClick: false,
|
allowOutsideClick: false,
|
||||||
didOpen: () => {
|
didOpen: () => Swal.showLoading()
|
||||||
Swal.showLoading();
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
fetch(`{{ url('/surveyor/signatures') }}`, {
|
fetch(`{{ url('/surveyor/signatures') }}`, {
|
||||||
@@ -177,7 +226,6 @@
|
|||||||
text: 'Tanda tangan berhasil disimpan!',
|
text: 'Tanda tangan berhasil disimpan!',
|
||||||
timer: 1500
|
timer: 1500
|
||||||
});
|
});
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
throw new Error(data.message || 'Terjadi kesalahan');
|
throw new Error(data.message || 'Terjadi kesalahan');
|
||||||
}
|
}
|
||||||
@@ -188,40 +236,41 @@
|
|||||||
title: 'Error',
|
title: 'Error',
|
||||||
text: error.message || 'Terjadi kesalahan saat menyimpan tanda tangan'
|
text: error.message || 'Terjadi kesalahan saat menyimpan tanda tangan'
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function loadSignature(type) {
|
function loadSignature(type, signaturePad) {
|
||||||
|
const nameInputElement = document.getElementById(`name-${type}`);
|
||||||
const params = new URLSearchParams({
|
const params = new URLSearchParams({
|
||||||
document_id: document.getElementById('dokument_id')?.value,
|
document_id: document.getElementById('dokument_id')?.value,
|
||||||
permohonan_id: document.getElementById('permohonan_id')?.value
|
permohonan_id: document.getElementById('permohonan_id')?.value
|
||||||
});
|
});
|
||||||
|
|
||||||
fetch(`{{ url('/surveyor/signatures/${type}?${params}') }}`)
|
fetch(`{{ url('/surveyor/signatures/${type}') }}?${params}`)
|
||||||
.then(response => response.json())
|
.then(response => response.json())
|
||||||
.then(data => {
|
.then(data => {
|
||||||
if (data.success && data.data?.signature) {
|
if (data.success && data.data?.signature) {
|
||||||
const canvas = document.getElementById(`signature-pad-${type}`);
|
drawSignature(signaturePad, data.data.signature);
|
||||||
if (!canvas) return;
|
|
||||||
|
|
||||||
const signaturePad = signaturePads[type];
|
|
||||||
const image = new Image();
|
|
||||||
|
|
||||||
image.onload = function() {
|
|
||||||
const context = canvas.getContext('2d');
|
|
||||||
context.clearRect(0, 0, canvas.width, canvas.height);
|
|
||||||
context.drawImage(image, 0, 0, canvas.width, canvas.height);
|
|
||||||
};
|
|
||||||
image.src = data.data.signature;
|
|
||||||
}
|
}
|
||||||
|
if (nameInputElement) {
|
||||||
|
nameInputElement.value = data.data?.name || '';
|
||||||
|
}
|
||||||
|
|
||||||
})
|
})
|
||||||
.catch(error => {
|
.catch(error => console.error('Error loading signature:', error));
|
||||||
console.error('Error loading signature:', error);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function deleteSignature(type) {
|
function drawSignature(signaturePad, imageUrl) {
|
||||||
|
const image = new Image();
|
||||||
|
image.onload = function() {
|
||||||
|
const ctx = signaturePad.canvas.getContext('2d');
|
||||||
|
ctx.clearRect(0, 0, signaturePad.canvas.width, signaturePad.canvas.height);
|
||||||
|
ctx.drawImage(image, 0, 0, signaturePad.canvas.width, signaturePad.canvas.height);
|
||||||
|
};
|
||||||
|
image.src = imageUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
function deleteSignature(type, signaturePad) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
title: 'Konfirmasi',
|
title: 'Konfirmasi',
|
||||||
text: 'Apakah Anda yakin ingin menghapus tanda tangan ini?',
|
text: 'Apakah Anda yakin ingin menghapus tanda tangan ini?',
|
||||||
@@ -248,7 +297,7 @@
|
|||||||
.then(response => response.json())
|
.then(response => response.json())
|
||||||
.then(data => {
|
.then(data => {
|
||||||
if (data.success) {
|
if (data.success) {
|
||||||
clearSignature(type);
|
clearSignature(signaturePad);
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
icon: 'success',
|
icon: 'success',
|
||||||
title: 'Berhasil',
|
title: 'Berhasil',
|
||||||
@@ -266,26 +315,13 @@
|
|||||||
text: error.message ||
|
text: error.message ||
|
||||||
'Terjadi kesalahan saat menghapus tanda tangan'
|
'Terjadi kesalahan saat menghapus tanda tangan'
|
||||||
});
|
});
|
||||||
console.error('Error:', error);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function clearSignature(type) {
|
function clearSignature(signaturePad) {
|
||||||
const signaturePad = signaturePads[type];
|
|
||||||
if (signaturePad) {
|
|
||||||
signaturePad.clear();
|
signaturePad.clear();
|
||||||
updateStatus(type, '');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function updateStatus(type, message, status = '') {
|
|
||||||
const statusElement = document.getElementById(`status-${type}`);
|
|
||||||
if (statusElement) {
|
|
||||||
statusElement.textContent = message;
|
|
||||||
statusElement.className = `status-message ${status}`;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Handle window resize untuk canvas responsif
|
// Handle window resize untuk canvas responsif
|
||||||
@@ -293,22 +329,18 @@
|
|||||||
types.forEach(type => {
|
types.forEach(type => {
|
||||||
const canvas = document.getElementById(`signature-pad-${type}`);
|
const canvas = document.getElementById(`signature-pad-${type}`);
|
||||||
if (canvas) {
|
if (canvas) {
|
||||||
const ratio = Math.max(window.devicePixelRatio || 1, 1);
|
setCanvasSize(canvas);
|
||||||
canvas.width = canvas.offsetWidth * ratio;
|
const signaturePad = signaturePads[type];
|
||||||
canvas.height = canvas.offsetHeight * ratio;
|
if (type === 'penilai' || type === 'cabang') {
|
||||||
canvas.getContext('2d').scale(ratio, ratio);
|
loadPenilaiAndCabangSignature(type, signaturePad);
|
||||||
|
} else {
|
||||||
// Reload signature jika ada
|
loadSignature(type, signaturePad);
|
||||||
loadSignature(type);
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
function submitData() {
|
function submitData() {
|
||||||
showLoadingSwal('Mengirim data ke server...');
|
showLoadingSwal('Mengirim data ke server...');
|
||||||
const form = document.querySelector('form');
|
const form = document.querySelector('form');
|
||||||
@@ -399,7 +431,5 @@
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<script></script>
|
|
||||||
@include('lpj::surveyor.js.utils')
|
@include('lpj::surveyor.js.utils')
|
||||||
@endpush
|
@endpush
|
||||||
|
|||||||
@@ -627,26 +627,43 @@
|
|||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
<table style="width: 100%; border-collapse: collapse; text-align: center;">
|
<table style="width: 100%; border-collapse: collapse; text-align: center;">
|
||||||
|
|
||||||
<tr>
|
<tr>
|
||||||
<!-- PENILAI -->
|
@if (isset($forminspeksi['signature']['penilai']['image']) && !empty($forminspeksi['signature']['penilai']['image']))
|
||||||
@if (isset($forminspeksi['signature']['penilai']))
|
@php
|
||||||
|
$imagePath = $forminspeksi['signature']['penilai']['image'];
|
||||||
|
|
||||||
|
$isBase64 = str_starts_with($imagePath, 'data:image');
|
||||||
|
|
||||||
|
if (!$isBase64) {
|
||||||
|
$relativePath = str_replace(url('storage') . '/', '', $imagePath);
|
||||||
|
$absolutePath = storage_path('app/public/' . $relativePath);
|
||||||
|
} else {
|
||||||
|
$absolutePath = $imagePath;
|
||||||
|
}
|
||||||
|
|
||||||
|
@endphp
|
||||||
<td style="width: 100px;">
|
<td style="width: 100px;">
|
||||||
<img style="width: 100px;" src="{{ $forminspeksi['signature']['penilai']['image'] }}"
|
<img style="width: 100px;" src="{{ $absolutePath }}" alt="">
|
||||||
alt="Penilai">
|
|
||||||
</td>
|
</td>
|
||||||
@else
|
|
||||||
<td style="width: 100px;">-</td>
|
|
||||||
@endif
|
@endif
|
||||||
|
|
||||||
|
|
||||||
@if (isset($forminspeksi['signature']['cabang']))
|
@if (isset($forminspeksi['signature']['cabang']))
|
||||||
|
@php
|
||||||
|
$imagePath = $forminspeksi['signature']['cabang']['image'];
|
||||||
|
|
||||||
|
$isBase64 = str_starts_with($imagePath, 'data:image');
|
||||||
|
|
||||||
|
if (!$isBase64) {
|
||||||
|
$relativePath = str_replace(url('storage') . '/', '', $imagePath);
|
||||||
|
$absolutePath = storage_path('app/public/' . $relativePath);
|
||||||
|
} else {
|
||||||
|
$absolutePath = $imagePath;
|
||||||
|
}
|
||||||
|
|
||||||
|
@endphp
|
||||||
<td style="width: 100px;">
|
<td style="width: 100px;">
|
||||||
<img style="width: 100px;" src="{{ $forminspeksi['signature']['cabang']['image'] }}"
|
<img style="width: 100px;" src="{{ $absolutePath }}" alt="">
|
||||||
alt="Cabang">
|
|
||||||
</td>
|
</td>
|
||||||
@else
|
|
||||||
<td style="width: 100px;">-</td>
|
|
||||||
@endif
|
@endif
|
||||||
|
|
||||||
|
|
||||||
@@ -655,8 +672,6 @@
|
|||||||
<img style="width: 100px;" src="{{ $forminspeksi['signature']['debitur']['image'] }}"
|
<img style="width: 100px;" src="{{ $forminspeksi['signature']['debitur']['image'] }}"
|
||||||
alt="Debitur/Perwakilan">
|
alt="Debitur/Perwakilan">
|
||||||
</td>
|
</td>
|
||||||
@else
|
|
||||||
<td style="width: 100px;">-</td>
|
|
||||||
@endif
|
@endif
|
||||||
|
|
||||||
<!-- K.J.P.P -->
|
<!-- K.J.P.P -->
|
||||||
@@ -665,30 +680,41 @@
|
|||||||
<img style="width: 100px;" src="{{ $forminspeksi['signature']['kjjp']['image'] }}"
|
<img style="width: 100px;" src="{{ $forminspeksi['signature']['kjjp']['image'] }}"
|
||||||
alt="KJPP">
|
alt="KJPP">
|
||||||
</td>
|
</td>
|
||||||
@else
|
|
||||||
<td style="width: 100px;">-</td>
|
|
||||||
@endif
|
@endif
|
||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
|
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding: 4px;">
|
@if (isset($forminspeksi['signature']['penilai']['name']))
|
||||||
|
<td style=" text-align: center">
|
||||||
|
<span>{{ ucwords(strtolower($forminspeksi['signature']['penilai']['name'])) }}</span>
|
||||||
|
<br />
|
||||||
<span>{{ ucwords(strtolower('PENILAI')) }}</span>
|
<span>{{ ucwords(strtolower('PENILAI')) }}</span>
|
||||||
</td>
|
</td>
|
||||||
<td style="padding: 4px;">
|
@endif
|
||||||
|
@if (isset($forminspeksi['signature']['cabang']['name']))
|
||||||
|
<td style=" text-align: center">
|
||||||
|
<span>{{ ucwords(strtolower($forminspeksi['signature']['cabang']['name'])) }}</span>
|
||||||
|
<br />
|
||||||
<span>{{ ucwords(strtolower('CABANG')) }}</span>
|
<span>{{ ucwords(strtolower('CABANG')) }}</span>
|
||||||
</td>
|
</td>
|
||||||
<td style="padding: 4px;">
|
@endif
|
||||||
|
@if (isset($forminspeksi['signature']['debitur']['name']))
|
||||||
|
<td style=" text-align: center">
|
||||||
|
<span>{{ ucwords(strtolower($forminspeksi['signature']['debitur']['name'])) }}</span>
|
||||||
|
<br />
|
||||||
<span>{{ ucwords(strtolower('DEBITUR/PERWAKILAN')) }}</span>
|
<span>{{ ucwords(strtolower('DEBITUR/PERWAKILAN')) }}</span>
|
||||||
</td>
|
</td>
|
||||||
<td style="padding: 4px;">
|
@endif
|
||||||
|
@if (isset($forminspeksi['signature']['kjjp']['name']))
|
||||||
|
<td style=" text-align: center">
|
||||||
|
<span>{{ ucwords(strtolower($forminspeksi['signature']['kjjp']['name'])) }}</span>
|
||||||
|
<br />
|
||||||
<span>{{ strtoupper('K.J.P.P') }}</span>
|
<span>{{ strtoupper('K.J.P.P') }}</span>
|
||||||
</td>
|
</td>
|
||||||
|
@endif
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
@@ -699,12 +725,6 @@
|
|||||||
<footer id="footer">
|
<footer id="footer">
|
||||||
Cabang : {{ $permohonan->debiture->branch->name ?? '' }}
|
Cabang : {{ $permohonan->debiture->branch->name ?? '' }}
|
||||||
</footer>
|
</footer>
|
||||||
|
|
||||||
<script>
|
|
||||||
const datas = @json($forminspeksi)
|
|
||||||
|
|
||||||
console.log(datas);
|
|
||||||
</script>
|
|
||||||
</body>
|
</body>
|
||||||
|
|
||||||
</html>
|
</html>
|
||||||
|
|||||||
Reference in New Issue
Block a user