Merge branch 'staging' of https://git.putrakuningan.com/daengdeni/lpj into tender
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>
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -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>
|
||||||
|
@php
|
||||||
|
$fotoTempat = $forminspeksi['foto_tempat'] ?? null;
|
||||||
|
$fotoSrc = '';
|
||||||
|
|
||||||
@if ($forminspeksi)
|
if (is_array($fotoTempat)) {
|
||||||
@php
|
$fotoSrc = asset('storage/' . $fotoTempat[0]);
|
||||||
$fotoTempat = $forminspeksi['foto_tempat'] ?? null;
|
} elseif (!empty($fotoTempat)) {
|
||||||
@endphp
|
$fotoSrc = asset('storage/' . $fotoTempat);
|
||||||
|
}
|
||||||
|
@endphp
|
||||||
|
|
||||||
|
<img id="foto_tempat-preview" src="{{ $fotoSrc ?: asset('images/default-placeholder.png') }}"
|
||||||
|
alt="Foto Tempat" class="mt-2 max-w-full h-auto"
|
||||||
|
style="max-width: 30rem; {{ $fotoSrc ? '' : 'display: none;' }}">
|
||||||
|
|
||||||
@if (is_array($fotoTempat) && count($fotoTempat) > 0)
|
|
||||||
<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"
|
|
||||||
style="{{ isset($forminspeksi['foto_tempat']) ? '' : '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];
|
signaturePad.clear();
|
||||||
if (signaturePad) {
|
|
||||||
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']))
|
||||||
<span>{{ ucwords(strtolower('PENILAI')) }}</span>
|
<td style=" text-align: center">
|
||||||
</td>
|
<span>{{ ucwords(strtolower($forminspeksi['signature']['penilai']['name'])) }}</span>
|
||||||
<td style="padding: 4px;">
|
<br />
|
||||||
<span>{{ ucwords(strtolower('CABANG')) }}</span>
|
<span>{{ ucwords(strtolower('PENILAI')) }}</span>
|
||||||
</td>
|
</td>
|
||||||
<td style="padding: 4px;">
|
@endif
|
||||||
<span>{{ ucwords(strtolower('DEBITUR/PERWAKILAN')) }}</span>
|
@if (isset($forminspeksi['signature']['cabang']['name']))
|
||||||
</td>
|
<td style=" text-align: center">
|
||||||
<td style="padding: 4px;">
|
<span>{{ ucwords(strtolower($forminspeksi['signature']['cabang']['name'])) }}</span>
|
||||||
<span>{{ strtoupper('K.J.P.P') }}</span>
|
<br />
|
||||||
</td>
|
<span>{{ ucwords(strtolower('CABANG')) }}</span>
|
||||||
|
</td>
|
||||||
|
@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>
|
||||||
|
</td>
|
||||||
|
@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>
|
||||||
|
</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