fix(penilai): perbaikkan keterangan freeze dan ubah name kjjp ke kjpp, handle key foto memo
This commit is contained in:
@@ -570,7 +570,7 @@ class PenilaiController extends Controller
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
$query->whereRaw('LOWER(status) IN (?, ?, ?, ?, ?, ?,?, ?)', ['assign', 'survey-completed', 'proses-laporan', 'paparan', 'proses-paparan', 'paparan', 'revisi-laporan', 'revisi-paparan']);
|
$query->whereRaw('LOWER(status) IN (?, ?, ?, ?, ?, ?,?, ?, ?, ?, ?)', ['assign', 'survey-completed', 'proses-laporan', 'paparan', 'proses-paparan', 'paparan', 'revisi-laporan', 'revisi-paparan', 'request-freeze', 'freeze', 'reject-freeze']);
|
||||||
|
|
||||||
if (!Auth::user()->hasRole('administrator')) {
|
if (!Auth::user()->hasRole('administrator')) {
|
||||||
$query->whereHas('penilaian.userPenilai', function ($q) {
|
$query->whereHas('penilaian.userPenilai', function ($q) {
|
||||||
@@ -963,41 +963,6 @@ class PenilaiController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function storeMemo(Request $request)
|
|
||||||
{
|
|
||||||
try {
|
|
||||||
|
|
||||||
$validatedData = $request->validate([
|
|
||||||
'permohonan_id' => 'required|integer',
|
|
||||||
'document_id' => 'required|integer',
|
|
||||||
'inspeksi_id' => 'required|integer',
|
|
||||||
'memo' => 'required',
|
|
||||||
]);
|
|
||||||
Penilai::updateOrCreate(
|
|
||||||
[
|
|
||||||
'permohonan_id' => $validatedData['permohonan_id'],
|
|
||||||
'dokument_id' => $validatedData['document_id'],
|
|
||||||
'inspeksi_id' => $validatedData['inspeksi_id'],
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'memo' => json_encode($validatedData['memo']),
|
|
||||||
]
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
return response()->json([
|
|
||||||
'success' => true,
|
|
||||||
'message' => 'Berhasil saved memo'
|
|
||||||
], 200);
|
|
||||||
} catch (\Exception $e) {
|
|
||||||
return response()->json([
|
|
||||||
'success' => false,
|
|
||||||
'message' => 'Terjadi kesalahan',
|
|
||||||
'error' => $e->getMessage()
|
|
||||||
], 500);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function storeMemoWithPhotos(Request $request)
|
public function storeMemoWithPhotos(Request $request)
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
@@ -1021,6 +986,8 @@ class PenilaiController extends Controller
|
|||||||
]
|
]
|
||||||
);
|
);
|
||||||
|
|
||||||
|
$existingPhotos = isset($memo->memo) ? json_decode($memo->memo)->foto : [];
|
||||||
|
dd($existingPhotos);
|
||||||
// Simpan foto-foto
|
// Simpan foto-foto
|
||||||
if ($request->hasFile('foto_0')) {
|
if ($request->hasFile('foto_0')) {
|
||||||
$photoUrls = [];
|
$photoUrls = [];
|
||||||
@@ -1033,11 +1000,15 @@ class PenilaiController extends Controller
|
|||||||
$index++;
|
$index++;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Tambahkan URL foto ke data memo
|
$memoData['foto'] = array_merge($existingPhotos, $photoUrls);
|
||||||
$memoData['foto'] = $photoUrls;
|
|
||||||
$memo->memo = json_encode($memoData);
|
}else{
|
||||||
$memo->save();
|
$memoData['foto'] = $existingPhotos;
|
||||||
}
|
}
|
||||||
|
// Tambahkan URL foto ke data memo
|
||||||
|
$memoData['foto'] = $photoUrls;
|
||||||
|
$memo->memo = json_encode($memoData);
|
||||||
|
$memo->save();
|
||||||
|
|
||||||
return response()->json([
|
return response()->json([
|
||||||
'success' => true,
|
'success' => true,
|
||||||
|
|||||||
@@ -450,7 +450,7 @@ class PenilaianController extends Controller
|
|||||||
|
|
||||||
public function otorisatorUpdate(Request $request, $id, $context)
|
public function otorisatorUpdate(Request $request, $id, $context)
|
||||||
{
|
{
|
||||||
if ($context === 'SLA') {
|
if ($context === 'Freze SLA') {
|
||||||
$authorization = Authorization::with(['user'])->find($id);
|
$authorization = Authorization::with(['user'])->find($id);
|
||||||
if (!$authorization) {
|
if (!$authorization) {
|
||||||
return response()->json([
|
return response()->json([
|
||||||
@@ -513,7 +513,7 @@ class PenilaianController extends Controller
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'sla':
|
case 'freze sla':
|
||||||
if (Auth::user()->roles[0]->name === 'senior-officer' || Auth::user()->roles[0]->name === 'administrator' && $authorization->approve_so === null) {
|
if (Auth::user()->roles[0]->name === 'senior-officer' || Auth::user()->roles[0]->name === 'administrator' && $authorization->approve_so === null) {
|
||||||
$authorization->update([
|
$authorization->update([
|
||||||
'status' => '3',
|
'status' => '3',
|
||||||
@@ -633,7 +633,7 @@ class PenilaianController extends Controller
|
|||||||
'Pelaporan' => 'proses-laporan',
|
'Pelaporan' => 'proses-laporan',
|
||||||
'Pembayaran' => 'proses',
|
'Pembayaran' => 'proses',
|
||||||
'Pembatalan' => 'batal',
|
'Pembatalan' => 'batal',
|
||||||
'SLA' => 'freeze',
|
'SLA' => 'request-freeze',
|
||||||
'Paparan' => 'proses-paparan',
|
'Paparan' => 'proses-paparan',
|
||||||
default => '',
|
default => '',
|
||||||
};
|
};
|
||||||
@@ -665,7 +665,7 @@ class PenilaianController extends Controller
|
|||||||
$query->whereRaw('LOWER(status) = ?', [strtolower($status)]);
|
$query->whereRaw('LOWER(status) = ?', [strtolower($status)]);
|
||||||
} elseif ($status == 'batal') {
|
} elseif ($status == 'batal') {
|
||||||
$query->whereRaw('LOWER(status) = ?', [strtolower($status)]);
|
$query->whereRaw('LOWER(status) = ?', [strtolower($status)]);
|
||||||
} elseif ($status == 'freeze') {
|
} elseif ($status == 'request-freeze') {
|
||||||
$query->whereRaw('LOWER(status) = ?', [strtolower($status)]);
|
$query->whereRaw('LOWER(status) = ?', [strtolower($status)]);
|
||||||
} elseif ($status == 'proses-paparan') {
|
} elseif ($status == 'proses-paparan') {
|
||||||
$query->whereRaw('LOWER(status) IN (?, ?)', ['proses-paparan', 'paparan']);
|
$query->whereRaw('LOWER(status) IN (?, ?)', ['proses-paparan', 'paparan']);
|
||||||
@@ -891,7 +891,8 @@ class PenilaianController extends Controller
|
|||||||
|
|
||||||
public function revisiLaporan(Request $request, $id)
|
public function revisiLaporan(Request $request, $id)
|
||||||
{
|
{
|
||||||
if($request->dataHeader=='Paparan'){
|
// dd($request->all());
|
||||||
|
if($request->dataHeader=='Paparan' || $request->dataHeader=='Freze SLA'){
|
||||||
$authorization = Authorization::find($id);
|
$authorization = Authorization::find($id);
|
||||||
$permohonan = Permohonan::find($authorization->permohonan_id);
|
$permohonan = Permohonan::find($authorization->permohonan_id);
|
||||||
} else {
|
} else {
|
||||||
@@ -905,7 +906,13 @@ class PenilaianController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
$status = 'revisi-paparan';
|
$status = 'revisi-paparan';
|
||||||
} elseif ($permohonan->status === 'proses-laporan' && $userRole === 'EO Appraisal') {
|
}else if($permohonan->status === 'freeze'){
|
||||||
|
if ($authorization) {
|
||||||
|
$authorization->delete();
|
||||||
|
}
|
||||||
|
|
||||||
|
$status = 'reject-freeze';
|
||||||
|
}elseif ($permohonan->status === 'proses-laporan' && $userRole === 'EO Appraisal') {
|
||||||
$permohonan->update([
|
$permohonan->update([
|
||||||
'approval_so' => 0,
|
'approval_so' => 0,
|
||||||
'approval_so_at' => null,
|
'approval_so_at' => null,
|
||||||
|
|||||||
@@ -914,10 +914,16 @@ class SurveyorController extends Controller
|
|||||||
try {
|
try {
|
||||||
$permohonan = Permohonan::findOrFail($id);
|
$permohonan = Permohonan::findOrFail($id);
|
||||||
|
|
||||||
|
$permohonan->update([
|
||||||
|
'keterangan' => $request->keterangan,
|
||||||
|
'status' => 'request-freeze',
|
||||||
|
]);
|
||||||
|
|
||||||
Authorization::updateOrCreate([
|
Authorization::updateOrCreate([
|
||||||
'permohonan_id' => $permohonan->id,
|
'permohonan_id' => $permohonan->id,
|
||||||
'jenis' => 'sla'
|
'jenis' => 'sla',
|
||||||
], [
|
], [
|
||||||
|
'keterangan' => $request->keterangan,
|
||||||
'request' => 'freeze',
|
'request' => 'freeze',
|
||||||
'user_id' => Auth::user()->id
|
'user_id' => Auth::user()->id
|
||||||
]);
|
]);
|
||||||
@@ -2422,7 +2428,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,kjpp',
|
||||||
'name' => 'nullable|string',
|
'name' => 'nullable|string',
|
||||||
'document_id' => 'nullable|string'
|
'document_id' => 'nullable|string'
|
||||||
]);
|
]);
|
||||||
@@ -2529,7 +2535,7 @@ class SurveyorController extends Controller
|
|||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
$validator = Validator::make($request->all(), [
|
$validator = Validator::make($request->all(), [
|
||||||
'type' => 'required|in:penilai,cabang,debitur,kjjp'
|
'type' => 'required|in:penilai,cabang,debitur,kjpp'
|
||||||
]);
|
]);
|
||||||
|
|
||||||
if ($validator->fails()) {
|
if ($validator->fails()) {
|
||||||
|
|||||||
@@ -295,9 +295,11 @@
|
|||||||
</table>
|
</table>
|
||||||
</main>
|
</main>
|
||||||
<div class="page-break"></div>
|
<div class="page-break"></div>
|
||||||
|
@if (isset($memo['foto']))
|
||||||
|
|
||||||
<table width="100%" border="0" style="align-content: center; text-align: center; margin-bottom: 20px">
|
<table width="100%" border="0" style="align-content: center; text-align: center; margin-bottom: 20px">
|
||||||
@foreach ($memo['foto'] as $item)
|
@foreach ($memo['foto'] as $item)
|
||||||
@php
|
@php
|
||||||
$cleanedPath = str_replace('/storage/', '', $item);
|
$cleanedPath = str_replace('/storage/', '', $item);
|
||||||
$imagePath = storage_path('app/public/' . $cleanedPath);
|
$imagePath = storage_path('app/public/' . $cleanedPath);
|
||||||
@endphp
|
@endphp
|
||||||
@@ -307,7 +309,7 @@
|
|||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
@endforeach
|
@endforeach
|
||||||
|
|
||||||
</table>
|
</table>
|
||||||
|
@endif
|
||||||
|
|
||||||
@include('lpj::penilai.components.footer')
|
@include('lpj::penilai.components.footer')
|
||||||
|
|||||||
@@ -232,7 +232,7 @@
|
|||||||
actions: {
|
actions: {
|
||||||
title: 'Action',
|
title: 'Action',
|
||||||
render: (item, data) => {
|
render: (item, data) => {
|
||||||
if (data.status === 'survey-completed' || data.status === 'proses-laporan' || data.status === 'paparan' || data.status === 'proses-paparan' || data.status === 'paparan' || data.status == 'revisi-laporan' || data.status === 'done' || data.status === 'revisi-paparan') {
|
if (data.status === 'survey-completed' || data.status === 'proses-laporan' || data.status === 'paparan' || data.status === 'proses-paparan' || data.status === 'paparan' || data.status == 'revisi-laporan' || data.status === 'done' || data.status === 'revisi-paparan' || data.status === 'reject-freeze' || data.status === 'freeze' || data.status === 'request-freeze') {
|
||||||
return `
|
return `
|
||||||
<div class="flex flex-nowrap justify-center gap-1.5">
|
<div class="flex flex-nowrap justify-center gap-1.5">
|
||||||
<a class="btn btn-sm btn-icon btn-clear btn-info" href="penilai/${data.id}/show">
|
<a class="btn btn-sm btn-icon btn-clear btn-info" href="penilai/${data.id}/show">
|
||||||
@@ -298,7 +298,7 @@ Swal.fire({
|
|||||||
url: `/surveyor/storeFreeze/${permohonanId}`,
|
url: `/surveyor/storeFreeze/${permohonanId}`,
|
||||||
type: 'POST',
|
type: 'POST',
|
||||||
data: {
|
data: {
|
||||||
message: userMessage
|
keterangan: userMessage
|
||||||
},
|
},
|
||||||
success: (response) => {
|
success: (response) => {
|
||||||
Swal.fire('Berhasil!',
|
Swal.fire('Berhasil!',
|
||||||
|
|||||||
@@ -183,7 +183,7 @@
|
|||||||
return `${data.permohonan.debiture.name}`;
|
return `${data.permohonan.debiture.name}`;
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
alasan: {
|
keterangan: {
|
||||||
title: 'Alasan',
|
title: 'Alasan',
|
||||||
},
|
},
|
||||||
request: {
|
request: {
|
||||||
|
|||||||
@@ -78,7 +78,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="card-body grid gap-5">
|
<div class="card-body grid gap-5">
|
||||||
{{ $authorization->alasan ?? ''}}
|
{{ $authorization->keterangan ?? ''}}
|
||||||
<table class="table table-border">
|
<table class="table table-border">
|
||||||
<tbody>
|
<tbody>
|
||||||
<tr>
|
<tr>
|
||||||
@@ -87,7 +87,7 @@
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>Alasan</td>
|
<td>Alasan</td>
|
||||||
<td>{{ $authorization->alasan }}</td>
|
<td>{{ $authorization->keterangan }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>Tanggal Permohonan</td>
|
<td>Tanggal Permohonan</td>
|
||||||
@@ -163,21 +163,21 @@
|
|||||||
@endif
|
@endif
|
||||||
|
|
||||||
@if(Auth::user()->hasAnyRole(['administrator','senior-officer']) && $authorization->approve_so==null)
|
@if(Auth::user()->hasAnyRole(['administrator','senior-officer']) && $authorization->approve_so==null)
|
||||||
<button onclick="otorisatorData({{ $authorization->id }})" type="button" class="btn btn-primary">
|
<button onclick="otorisatorData({{ $authorization->id }}, 'SO')" type="button" class="btn btn-primary">
|
||||||
<i class="ki-filled ki-double-check"></i>
|
<i class="ki-filled ki-double-check"></i>
|
||||||
Otorisasi {{ $header ?? '' }}
|
Otorisasi {{ $header ?? '' }}
|
||||||
</button>
|
</button>
|
||||||
@endif
|
@endif
|
||||||
|
|
||||||
@if(Auth::user()->hasAnyRole(['administrator','EO Appraisal']) && $authorization->approve_so && $authorization->approve_eo==null)
|
@if(Auth::user()->hasAnyRole(['administrator','EO Appraisal']) && $authorization->approve_so && $authorization->approve_eo==null)
|
||||||
<button onclick="otorisatorData({{ $authorization->id }})" type="button" class="btn btn-primary">
|
<button onclick="otorisatorData({{ $authorization->id }}, 'EO')" type="button" class="btn btn-primary">
|
||||||
<i class="ki-filled ki-double-check"></i>
|
<i class="ki-filled ki-double-check"></i>
|
||||||
Otorisasi {{ $header ?? '' }}
|
Otorisasi {{ $header ?? '' }}
|
||||||
</button>
|
</button>
|
||||||
@endif
|
@endif
|
||||||
|
|
||||||
@if(Auth::user()->hasAnyRole(['administrator','DD Appraisal']) && $authorization->approve_eo && $authorization->approve_dd==null && in_array($permohonan->nilai_plafond_id,[1,4]))
|
@if(Auth::user()->hasAnyRole(['administrator','DD Appraisal']) && $authorization->approve_eo && $authorization->approve_dd==null && in_array($permohonan->nilai_plafond_id,[1, 4]))
|
||||||
<button onclick="otorisatorData({{ $authorization->id }})" type="button" class="btn btn-primary">
|
<button onclick="otorisatorData({{ $authorization->id }}, 'DD')" type="button" class="btn btn-primary">
|
||||||
<i class="ki-filled ki-double-check"></i>
|
<i class="ki-filled ki-double-check"></i>
|
||||||
Otorisasi {{ $header ?? '' }}
|
Otorisasi {{ $header ?? '' }}
|
||||||
</button>
|
</button>
|
||||||
@@ -188,52 +188,149 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script>
|
|
||||||
function otorisatorData(dataId) {
|
|
||||||
const dataHeader = @json($header);
|
<script>
|
||||||
Swal.fire({
|
const handleRejection = (dataId,dataHeader='') => {
|
||||||
title: 'Apakah Anda yakin?',
|
Swal.fire({
|
||||||
text: `Untuk melakukan otorisator ${dataHeader}!`,
|
title: 'Masukkan alasan penolakan:',
|
||||||
icon: 'warning',
|
input: 'textarea',
|
||||||
input: 'textarea',
|
inputPlaceholder: 'Tuliskan alasan...',
|
||||||
inputLabel: 'Keterangan',
|
showCancelButton: true,
|
||||||
inputPlaceholder: 'Masukkan keterangan...',
|
confirmButtonColor: '#f39c12',
|
||||||
inputAttributes: {
|
cancelButtonColor: '#d33',
|
||||||
'aria-label': 'Masukkan keterangan'
|
confirmButtonText: 'Kirim',
|
||||||
},
|
cancelButtonText: 'Batal',
|
||||||
showCancelButton: true,
|
preConfirm: (alasan) => {
|
||||||
confirmButtonColor: '#3085d6',
|
if (!alasan) {
|
||||||
cancelButtonColor: '#d33',
|
Swal.showValidationMessage('Alasan harus diisi!');
|
||||||
confirmButtonText: 'Ya, Lanjutkan!',
|
return false;
|
||||||
cancelButtonText: 'Batal',
|
|
||||||
}).then((result) => {
|
|
||||||
if (result.isConfirmed) {
|
|
||||||
const userMessage = result.value || ''; // Ambil pesan dari textarea
|
|
||||||
$.ajaxSetup({
|
|
||||||
headers: {
|
|
||||||
'X-CSRF-TOKEN': '{{ csrf_token() }}'
|
|
||||||
},
|
|
||||||
});
|
|
||||||
$.ajax({
|
|
||||||
url: `/otorisator/otorisator/${dataId}/SLA`,
|
|
||||||
type: 'POST',
|
|
||||||
data: {
|
|
||||||
message: userMessage
|
|
||||||
},
|
|
||||||
success: (response) => {
|
|
||||||
Swal.fire('Berhasil!', 'Data berhasil diotorisasi. Menunggu Approval EO dan atau DD', 'success').then(() => {
|
|
||||||
window.location.reload();
|
|
||||||
});
|
|
||||||
console.log(response);
|
|
||||||
},
|
|
||||||
error: (error) => {
|
|
||||||
console.error('Error:', error);
|
|
||||||
Swal.fire('Gagal!', 'Terjadi kesalahan saat melakukan otorisator.',
|
|
||||||
'error');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
});
|
return alasan;
|
||||||
}
|
}
|
||||||
</script>
|
}).then((rejectResult) => {
|
||||||
|
if (rejectResult.isConfirmed) {
|
||||||
|
handleAjaxRequest(
|
||||||
|
`/otorisator/revisi-laporan/${dataId}`, {
|
||||||
|
keterangan: rejectResult.value,
|
||||||
|
dataHeader: dataHeader
|
||||||
|
},
|
||||||
|
'Data berhasil ditolak.',
|
||||||
|
'Terjadi kesalahan saat melakukan penolakan.'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
const showSwalConfirmation = (
|
||||||
|
title, text, html, confirmText, denyText, cancelText, preConfirm, icon = 'question'
|
||||||
|
) => {
|
||||||
|
return Swal.fire({
|
||||||
|
title: title,
|
||||||
|
text: text,
|
||||||
|
html: html,
|
||||||
|
icon: icon,
|
||||||
|
focusConfirm: false,
|
||||||
|
preConfirm: preConfirm,
|
||||||
|
showCancelButton: true,
|
||||||
|
showDenyButton: !!denyText,
|
||||||
|
confirmButtonColor: '#3085d6',
|
||||||
|
cancelButtonColor: '#d33',
|
||||||
|
denyButtonColor: '#f39c12',
|
||||||
|
confirmButtonText: confirmText,
|
||||||
|
denyButtonText: denyText,
|
||||||
|
cancelButtonText: cancelText,
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
const handleAjaxRequest = (url, data, successMessage, errorMessage) => {
|
||||||
|
$.ajaxSetup({
|
||||||
|
headers: {
|
||||||
|
'X-CSRF-TOKEN': '{{ csrf_token() }}'
|
||||||
|
},
|
||||||
|
});
|
||||||
|
$.ajax({
|
||||||
|
url: url,
|
||||||
|
type: 'POST',
|
||||||
|
data: data,
|
||||||
|
success: () => {
|
||||||
|
Swal.fire('Berhasil!', successMessage, 'success').then(() => {
|
||||||
|
const dataHeader = @json($header);
|
||||||
|
const redirectUrl = `/otorisator/sla`;
|
||||||
|
window.location.href = redirectUrl;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
error: (error) => {
|
||||||
|
console.error('Error:', error);
|
||||||
|
Swal.fire('Gagal!', errorMessage, 'error');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function otorisatorData(dataId, role = '') {
|
||||||
|
const dataHeader = @json($header);
|
||||||
|
const isPaparanSO = dataHeader === 'SLA' && role === 'SO';
|
||||||
|
|
||||||
|
const swalHtml = isPaparanSO ? `
|
||||||
|
<div class="text-left space-y-4">
|
||||||
|
<p class="text-gray-700 text-center">Untuk melakukan otorisasi ${dataHeader}!</p>
|
||||||
|
<div>
|
||||||
|
<label for="swal-keterangan" class="block text-sm font-medium text-gray-700 mb-1">Keterangan</label>
|
||||||
|
<input id="swal-keterangan" class="input" placeholder="Masukkan Keterangan">
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<label for="swal-tanggal-paparan" class="block text-sm font-medium text-gray-700 mb-1">Tanggal Paparan</label>
|
||||||
|
<input id="swal-tanggal-paparan" class="input" type="date" placeholder="Tanggal paparan">
|
||||||
|
</div>
|
||||||
|
</div>` : '';
|
||||||
|
|
||||||
|
showSwalConfirmation(
|
||||||
|
'Apakah Anda yakin?',
|
||||||
|
`Untuk melakukan otorisasi ${dataHeader}!`,
|
||||||
|
swalHtml,
|
||||||
|
'Ya, Lanjutkan!',
|
||||||
|
'Tolak',
|
||||||
|
'Batal',
|
||||||
|
() => {
|
||||||
|
if (isPaparanSO) {
|
||||||
|
const message = document.getElementById('swal-keterangan')?.value;
|
||||||
|
const tanggalPaparan = document.getElementById('swal-tanggal-paparan').value;
|
||||||
|
|
||||||
|
if (!message || !tanggalPaparan) {
|
||||||
|
Swal.showValidationMessage('Keterangan dan Tanggal Paparan harus diisi!');
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
message,
|
||||||
|
tanggalPaparan
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
return {
|
||||||
|
message: 'Ya, lanjutkan.'
|
||||||
|
};
|
||||||
|
}
|
||||||
|
},
|
||||||
|
'question'
|
||||||
|
).then((result) => {
|
||||||
|
if (result.isConfirmed) {
|
||||||
|
const requestData = isPaparanSO ? {
|
||||||
|
keterangan: result.value.message,
|
||||||
|
tanggalPaparan: result.value.tanggalPaparan
|
||||||
|
} : {
|
||||||
|
keterangan: result.value.message
|
||||||
|
};
|
||||||
|
|
||||||
|
handleAjaxRequest(
|
||||||
|
`/otorisator/otorisator/${dataId}/${dataHeader}`,
|
||||||
|
requestData,
|
||||||
|
'Data berhasil diotorisasi.',
|
||||||
|
'Terjadi kesalahan saat melakukan otorisasi.'
|
||||||
|
);
|
||||||
|
} else if (result.isDenied) {
|
||||||
|
handleRejection(dataId,dataHeader);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
</script>
|
||||||
@endpush
|
@endpush
|
||||||
|
|||||||
@@ -54,7 +54,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<div class="flex items-baseline justify-between flex-wrap lg:flex-nowrap">
|
<div class="flex items-baseline justify-between flex-wrap lg:flex-nowrap">
|
||||||
@foreach (['penilai', 'cabang', 'debitur', 'kjjp'] as $type)
|
@foreach (['penilai', 'cabang', 'debitur', 'kjpp'] as $type)
|
||||||
@include('lpj::component.signature-pad', ['type' => $type])
|
@include('lpj::component.signature-pad', ['type' => $type])
|
||||||
@endforeach
|
@endforeach
|
||||||
|
|
||||||
@@ -95,7 +95,7 @@
|
|||||||
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', 'kjpp'];
|
||||||
|
|
||||||
// Initialize all signature pads
|
// Initialize all signature pads
|
||||||
types.forEach(type => initSignaturePad(type));
|
types.forEach(type => initSignaturePad(type));
|
||||||
|
|||||||
@@ -574,10 +574,10 @@
|
|||||||
@endif
|
@endif
|
||||||
|
|
||||||
<!-- K.J.P.P -->
|
<!-- K.J.P.P -->
|
||||||
@if (isset($forminspeksi['signature']['kjjp']))
|
@if (isset($forminspeksi['signature']['kjpp']))
|
||||||
<td style="width: 100px;">
|
<td style="width: 100px;">
|
||||||
<img style="width: 100px;"
|
<img style="width: 100px;"
|
||||||
src="{{ $forminspeksi['signature']['kjjp']['image'] }}" alt="KJPP">
|
src="{{ $forminspeksi['signature']['kjpp']['image'] }}" alt="KJPP">
|
||||||
</td>
|
</td>
|
||||||
@endif
|
@endif
|
||||||
</tr>
|
</tr>
|
||||||
@@ -605,9 +605,9 @@
|
|||||||
<span>{{ ucwords(strtolower('DEBITUR/PERWAKILAN')) }}</span>
|
<span>{{ ucwords(strtolower('DEBITUR/PERWAKILAN')) }}</span>
|
||||||
</td>
|
</td>
|
||||||
@endif
|
@endif
|
||||||
@if (isset($forminspeksi['signature']['kjjp']['name']))
|
@if (isset($forminspeksi['signature']['kjpp']['name']))
|
||||||
<td style=" text-align: center">
|
<td style=" text-align: center">
|
||||||
<span>{{ ucwords(strtolower($forminspeksi['signature']['kjjp']['name'])) }}</span>
|
<span>{{ ucwords(strtolower($forminspeksi['signature']['kjpp']['name'])) }}</span>
|
||||||
<br />
|
<br />
|
||||||
<span>{{ strtoupper('K.J.P.P') }}</span>
|
<span>{{ strtoupper('K.J.P.P') }}</span>
|
||||||
</td>
|
</td>
|
||||||
|
|||||||
Reference in New Issue
Block a user