diff --git a/app/Http/Controllers/DebitureController.php b/app/Http/Controllers/DebitureController.php index c8b6c8b..98a76fe 100644 --- a/app/Http/Controllers/DebitureController.php +++ b/app/Http/Controllers/DebitureController.php @@ -129,7 +129,7 @@ // Retrieve data from the database $query = Debiture::query(); - if (!Auth::user()->hasAnyRole(['administrator'])) { + if (!Auth::user()->hasAnyRole(['administrator','admin'])) { $query = $query->where('branch_id', Auth::user()->branch_id); } diff --git a/app/Http/Controllers/PembayaranController.php b/app/Http/Controllers/PembayaranController.php index 16fd2b9..9cdea71 100644 --- a/app/Http/Controllers/PembayaranController.php +++ b/app/Http/Controllers/PembayaranController.php @@ -245,7 +245,7 @@ class PembayaranController extends Controller $permohonan->approve_bayar_by = null; $permohonan->approve_bayar_at = null; - $permohonan->status = 'done'; + $permohonan->status = 'proses-laporan'; $permohonan->save(); } else { $persetujuanPenawaran = PersetujuanPenawaran::create( diff --git a/app/Http/Controllers/PenilaiController.php b/app/Http/Controllers/PenilaiController.php index 01d6f76..46900bd 100644 --- a/app/Http/Controllers/PenilaiController.php +++ b/app/Http/Controllers/PenilaiController.php @@ -157,7 +157,7 @@ class PenilaiController extends Controller $permohonan = $this->surveyorController->getPermohonanJaminanId($id, $documentId, $jaminanId); if ($permohonan->status == 'proses-laporan') { - return redirect()->back()->with('error', 'Masih dalam proses laporan'); + //return redirect()->back()->with('error', 'Masih dalam proses laporan'); } $basicData = $this->surveyorController->getCommonData(); @@ -841,10 +841,10 @@ class PenilaiController extends Controller $permohonan = Permohonan::findOrFail($id); if ($permohonan->status === 'proses-laporan') { - return response()->json([ + /*return response()->json([ 'success' => false, 'message' => 'Masih proses laporan', - ], 400); + ], 400);*/ } if ($permohonan->status === 'proses-paparan') { diff --git a/app/Http/Controllers/PenilaianController.php b/app/Http/Controllers/PenilaianController.php index 142dea2..38ebae1 100644 --- a/app/Http/Controllers/PenilaianController.php +++ b/app/Http/Controllers/PenilaianController.php @@ -518,7 +518,7 @@ class PenilaianController extends Controller $status = 'done'; $approvalField = null; - $lpj_ = optional(json_decode($permohonan->penilaian->lpj)); + $lpj_ = optional(json_decode($permohonan->penilai->lpj)); $npw = $lpj_->total_nilai_pasar_wajar ?? 0; $npw = str_replace('.', '', $npw); diff --git a/app/Http/Controllers/PermohonanController.php b/app/Http/Controllers/PermohonanController.php index 6fc8e56..cf911e3 100644 --- a/app/Http/Controllers/PermohonanController.php +++ b/app/Http/Controllers/PermohonanController.php @@ -50,6 +50,9 @@ { $validate = $request->validated(); if ($validate) { + if(auth()->user()->hasRole('admin')){ + $validate['status'] = "preregister"; + } try { // Process file upload $filePath = null; @@ -172,7 +175,7 @@ // Retrieve data from the database $query = Permohonan::query(); - if (!Auth::user()->hasAnyRole(['administrator'])) { + if (!Auth::user()->hasAnyRole(['administrator','admin'])) { $query = $query->where('branch_id', Auth::user()->branch_id); } @@ -371,14 +374,21 @@ } if ($permohonan->status == 'sudah_dibayar') { - $buktiBayar = $permohonan->documents->filter(function ($doc) { - return $doc->detail && $doc->detail->nama === 'Bukti Bayar'; + + $documents = $permohonan->dokumenjaminan->first(function ($doc) { + return $doc->detail && $doc->detail->contains('name', 'Bukti Bayar'); }); + $buktiBayar = $documents->detail->filter(function ($detail) { + return $detail->name == 'Bukti Bayar'; + })->first() ?? null; + if ($buktiBayar->isEmpty()) { return redirect()->route('authorization.show', $id)->with('error', 'Bukti Bayar harus diunggah'); } + $dokumenJaminan = json_decode($buktiBayar->dokumen_jaminan); + $persetujuanPenawaran = PersetujuanPenawaran::firstOrCreate( ['permohonan_id' => $id], [ diff --git a/app/Http/Controllers/SpkController.php b/app/Http/Controllers/SpkController.php index 2d9530a..1800e0c 100644 --- a/app/Http/Controllers/SpkController.php +++ b/app/Http/Controllers/SpkController.php @@ -345,6 +345,19 @@ use Illuminate\Support\Facades\Auth; $content = $pdf->download()->getOriginalContent(); Storage::put('public/'.$newFileNameWithPath,$content); + $permohonanModel = Permohonan::where('nomor_registrasi', $penawaran->nomor_registrasi)->first(); + if ($permohonanModel) { + $permohonanModel->status = 'registrasi-final'; + $permohonanModel->save(); + } + + $persetujuanPenawaran = PenawaranTender::where('id', $penawaran->id)->first(); + if ($persetujuanPenawaran) { + $persetujuanPenawaran->status = 'registrasi-final'; + $persetujuanPenawaran->save(); + } + + $data1['status'] = 'success'; $data1['spkpenawaran_path'] = $spkpenawaran_path; $data1['message']['message_success'] = array('Generate SPK PDF successfully'); diff --git a/app/Http/Requests/PermohonanRequest.php b/app/Http/Requests/PermohonanRequest.php index a3a579f..909987f 100644 --- a/app/Http/Requests/PermohonanRequest.php +++ b/app/Http/Requests/PermohonanRequest.php @@ -48,7 +48,6 @@ ), 'tanggal_permohonan' => date('Y-m-d'), 'user_id' => auth()->user()->id, - 'branch_id' => auth()->user()->branch_id, 'status' => 'order' ]); } diff --git a/module.json b/module.json index 4e073af..8185608 100644 --- a/module.json +++ b/module.json @@ -308,7 +308,8 @@ "permission": "", "roles": [ "administrator", - "pemohon-ao" + "pemohon-ao", + "admin" ] }, { @@ -320,7 +321,8 @@ "permission": "", "roles": [ "administrator", - "pemohon-ao" + "pemohon-ao", + "admin" ] }, { diff --git a/resources/views/component/form-penilai.blade.php b/resources/views/component/form-penilai.blade.php index d3103aa..148682d 100644 --- a/resources/views/component/form-penilai.blade.php +++ b/resources/views/component/form-penilai.blade.php @@ -438,13 +438,18 @@ function calculateTotal() { const parseInput = (value) => { if (!value) return 0; - return parseFloat(value.replace(/[^0-9]/g, '')) || 0; + // keep the dot as decimal separator, remove thousand separators + const cleaned = value.replace(/[^0-9.,]/g, '').replace(/\./g, '').replace(/,/g, '.'); + return parseFloat(cleaned) || 0; }; // Function to format currency function formatCurrency(value) { // Ensure we have a valid number to format - const num = parseFloat(value.replace(/[^0-9]/g, '')) || 0; + //const num = parseFloat(value.replace(/[^0-9]/g, '')) || 0; + //return num.toLocaleString('id-ID'); + let num = value.replace(/[^0-9.,]/g, '').replace(/\./g, '').replace(/,/g, '.'); + num = parseFloat(num) || 0; return num.toLocaleString('id-ID'); } diff --git a/resources/views/debitur/components/debitur.blade.php b/resources/views/debitur/components/debitur.blade.php index 348235f..724cfcd 100644 --- a/resources/views/debitur/components/debitur.blade.php +++ b/resources/views/debitur/components/debitur.blade.php @@ -10,7 +10,7 @@ *
- @if(auth()->user()->hasRole('administrator')) + @if(auth()->user()->hasRole('administrator','admin')) +
+ +
+ @if (auth()->user()->hasRole(['administrator','admin'])) + + @else + + + @endif + @error('branch_id') + {{ $message }} + @enderror +
+
+ @php $formFields = [ 'tujuan_penilaian_id' => ['label' => 'Tujuan Penilaian', 'type' => 'select', 'options' => $tujuanPenilaian], @@ -65,7 +92,7 @@ @endphp @foreach($formFields as $field => $config) -
+
@if($config['type'] === 'select') @@ -85,14 +112,14 @@ value="{{ old($field, $permohonan->$field ?? '') }}"> @endif @error($field) - {{ $message }} + {{ $message }} @enderror
@endforeach @if(isset($permohonan) && $permohonan->status == 'revisi') -
+
Catatan :
{{ $permohonan->keterangan }} {{ $permohonan->registrasi_catatan }}
diff --git a/resources/views/permohonan/index.blade.php b/resources/views/permohonan/index.blade.php index 15b57e2..0bd3892 100644 --- a/resources/views/permohonan/index.blade.php +++ b/resources/views/permohonan/index.blade.php @@ -22,7 +22,7 @@
Export to Excel - @if(auth()->user()->hasAnyRole(['administrator', 'pemohon-ao'])) + @if(auth()->user()->hasAnyRole(['administrator', 'pemohon-ao','admin'])) Tambah Permohonan @endif