Merge branch 'staging' into feature/senior-officer
This commit is contained in:
@@ -4,6 +4,7 @@
|
|||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use Exception;
|
use Exception;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Http\JsonResponse;
|
use Illuminate\Http\JsonResponse;
|
||||||
use Illuminate\Support\Collection;
|
use Illuminate\Support\Collection;
|
||||||
use Illuminate\Support\Facades\DB;
|
use Illuminate\Support\Facades\DB;
|
||||||
@@ -572,4 +573,40 @@
|
|||||||
$combinedLegalitas = array_merge($existingLegalitas, $newLegalitas);
|
$combinedLegalitas = array_merge($existingLegalitas, $newLegalitas);
|
||||||
return response()->json($combinedLegalitas);
|
return response()->json($combinedLegalitas);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function clearDetail(Request $request)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
DB::beginTransaction();
|
||||||
|
|
||||||
|
$detailId = $request->input('detail_id');
|
||||||
|
$detail = DetailDokumenJaminan::findOrFail($detailId);
|
||||||
|
|
||||||
|
// Delete associated files
|
||||||
|
if ($detail->dokumen_jaminan) {
|
||||||
|
$dokumen_jaminan = is_array(json_decode($detail->dokumen_jaminan))
|
||||||
|
? json_decode($detail->dokumen_jaminan)
|
||||||
|
: [$detail->dokumen_jaminan];
|
||||||
|
|
||||||
|
foreach ($dokumen_jaminan as $dokumen) {
|
||||||
|
if (Storage::exists($dokumen)) {
|
||||||
|
Storage::delete($dokumen);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Delete the detail record
|
||||||
|
$detail->delete();
|
||||||
|
|
||||||
|
DB::commit();
|
||||||
|
|
||||||
|
return response()->json(['success' => true, 'message' => 'Detail berhasil dihapus']);
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
DB::rollBack();
|
||||||
|
return response()->json([
|
||||||
|
'success' => false,
|
||||||
|
'message' => 'Gagal menghapus detail: ' . $e->getMessage()
|
||||||
|
], 500);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
173
app/Http/Controllers/LaporanExternalController.php
Normal file
173
app/Http/Controllers/LaporanExternalController.php
Normal file
@@ -0,0 +1,173 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Http\Controllers;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Modules\Lpj\Models\LaporanExternal;
|
||||||
|
use Modules\Lpj\Http\Requests\LaporanExternalRequest;
|
||||||
|
use Modules\Lpj\Models\Permohonan;
|
||||||
|
|
||||||
|
class LaporanExternalController extends Controller
|
||||||
|
{
|
||||||
|
public $user;
|
||||||
|
/**
|
||||||
|
* Display a listing of the resource.
|
||||||
|
*/
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
$laporanExternals = LaporanExternal::with('permohonan')->paginate(10);
|
||||||
|
return view('lpj::laporan_external.index', compact('laporanExternals'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Show the form for creating a new resource.
|
||||||
|
*/
|
||||||
|
public function create()
|
||||||
|
{
|
||||||
|
return view('lpj::laporan_external.create');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Store a newly created resource in storage.
|
||||||
|
*/
|
||||||
|
public function store(LaporanExternalRequest $request)
|
||||||
|
{
|
||||||
|
$validatedData = $request->validated();
|
||||||
|
|
||||||
|
if ($request->hasFile('file_resume')) {
|
||||||
|
$validatedData['file_resume'] = $request->file('file_resume')->store('laporan_external/resume', 'public');
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->hasFile('file_laporan')) {
|
||||||
|
$validatedData['file_laporan'] = $request->file('file_laporan')->store('laporan_external/laporan', 'public');
|
||||||
|
}
|
||||||
|
|
||||||
|
LaporanExternal::create($validatedData);
|
||||||
|
|
||||||
|
return redirect()->route('laporan-external.index')->with('success', 'Laporan External berhasil ditambahkan.');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Show the specified resource.
|
||||||
|
*/
|
||||||
|
public function show(LaporanExternal $laporanExternal)
|
||||||
|
{
|
||||||
|
return view('lpj::laporan_external.show', compact('laporanExternal'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Show the form for editing the specified resource.
|
||||||
|
*/
|
||||||
|
public function edit(LaporanExternal $laporanExternal)
|
||||||
|
{
|
||||||
|
$permohonan = Permohonan::find($laporanExternal->permohonan_id);
|
||||||
|
return view('lpj::laporan_external.create', compact('laporanExternal','permohonan'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update the specified resource in storage.
|
||||||
|
*/
|
||||||
|
public function update(LaporanExternalRequest $request, LaporanExternal $laporanExternal)
|
||||||
|
{
|
||||||
|
$validatedData = $request->validated();
|
||||||
|
|
||||||
|
if ($request->hasFile('file_resume')) {
|
||||||
|
$validatedData['file_resume'] = $request->file('file_resume')->store('laporan_external/resume', 'public');
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->hasFile('file_laporan')) {
|
||||||
|
$validatedData['file_laporan'] = $request->file('file_laporan')->store('laporan_external/laporan', 'public');
|
||||||
|
}
|
||||||
|
|
||||||
|
$laporanExternal->update($validatedData);
|
||||||
|
|
||||||
|
return redirect()->route('laporan-external.index')->with('success', 'Laporan External berhasil diperbarui.');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the specified resource from storage.
|
||||||
|
*/
|
||||||
|
public function destroy(LaporanExternal $laporanExternal)
|
||||||
|
{
|
||||||
|
$laporanExternal->delete();
|
||||||
|
|
||||||
|
return redirect()->route('laporan-external.index')->with('success', 'Laporan External berhasil dihapus.');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function dataForDatatables(Request $request)
|
||||||
|
{
|
||||||
|
if (is_null($this->user) || !$this->user->can('jenis_aset.view')) {
|
||||||
|
//abort(403, 'Sorry! You are not allowed to view users.');
|
||||||
|
}
|
||||||
|
|
||||||
|
// Retrieve data from the database
|
||||||
|
$query = LaporanExternal::query();
|
||||||
|
|
||||||
|
// Apply search filter if provided
|
||||||
|
if ($request->has('search') && !empty($request->get('search'))) {
|
||||||
|
$search = $request->get('search');
|
||||||
|
$query->where(function ($q) use ($search) {
|
||||||
|
$q->where('nomor_laporan', 'LIKE', "%$search%")
|
||||||
|
->orWhere('tanggal_laporan', 'LIKE', "%$search%")
|
||||||
|
->orWhereHas('permohonan', function($q) use ($search) {
|
||||||
|
$q->where('nomor_permohonan', 'LIKE', "%$search%");
|
||||||
|
})
|
||||||
|
->orWhere('tgl_final_laporan', 'LIKE', "%$search%")
|
||||||
|
->orWhere('nilai_pasar', 'LIKE', "%$search%")
|
||||||
|
->orWhere('indikasi_nilai_likuidasi', 'LIKE', "%$search%")
|
||||||
|
->orWhere('indikasi_nilai_pasar_tanah', 'LIKE', "%$search%")
|
||||||
|
->orWhere('estimasi_harga_tanah', 'LIKE', "%$search%")
|
||||||
|
->orWhere('estimasi_harga_bangunan', 'LIKE', "%$search%")
|
||||||
|
->orWhere('indikasi_nilai_pasar_bangunan', 'LIKE', "%$search%")
|
||||||
|
->orWhere('indikasi_nilai_pasar_sarana_pelengkap', 'LIKE', "%$search%")
|
||||||
|
->orWhere('indikasi_nilai_pasar_mesin', 'LIKE', "%$search%")
|
||||||
|
->orWhere('indikasi_nilai_pasar_kendaraan_alat_berat', 'LIKE', "%$search%")
|
||||||
|
->orWhere('file_resume', 'LIKE', "%$search%")
|
||||||
|
->orWhere('file_laporan', 'LIKE', "%$search%");
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Apply sorting if provided
|
||||||
|
if ($request->has('sortOrder') && !empty($request->get('sortOrder'))) {
|
||||||
|
$order = $request->get('sortOrder');
|
||||||
|
$column = $request->get('sortField');
|
||||||
|
$query->orderBy($column, $order);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the total count of records
|
||||||
|
$totalRecords = $query->count();
|
||||||
|
|
||||||
|
// Apply pagination if provided
|
||||||
|
if ($request->has('page') && $request->has('size')) {
|
||||||
|
$page = $request->get('page');
|
||||||
|
$size = $request->get('size');
|
||||||
|
$offset = ($page - 1) * $size; // Calculate the offset
|
||||||
|
|
||||||
|
$query->skip($offset)->take($size);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the filtered count of records
|
||||||
|
$filteredRecords = $query->count();
|
||||||
|
|
||||||
|
// Get the data for the current page
|
||||||
|
$data = $query->get();
|
||||||
|
|
||||||
|
// Calculate the page count
|
||||||
|
$pageCount = ceil($totalRecords / $request->get('size'));
|
||||||
|
|
||||||
|
// Calculate the current page number
|
||||||
|
$currentPage = 0 + 1;
|
||||||
|
|
||||||
|
// Return the response data as a JSON object
|
||||||
|
return response()->json([
|
||||||
|
'draw' => $request->get('draw'),
|
||||||
|
'recordsTotal' => $totalRecords,
|
||||||
|
'recordsFiltered' => $filteredRecords,
|
||||||
|
'pageCount' => $pageCount,
|
||||||
|
'page' => $currentPage,
|
||||||
|
'totalCount' => $totalRecords,
|
||||||
|
'data' => $data,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -336,8 +336,9 @@
|
|||||||
|
|
||||||
public function show($id)
|
public function show($id)
|
||||||
{
|
{
|
||||||
$prosespenawaran = PenawaranTender::find($id);
|
$prosespenawaran = PenawaranTender::with(['permohonan','tujuanPenilaianKjpp'])->find($id);
|
||||||
return view('lpj::otorisasipenawaran.show', compact('id','prosespenawaran'));
|
$permohonan = $prosespenawaran->permohonan;
|
||||||
|
return view('lpj::otorisasipenawaran.show', compact('id','prosespenawaran','permohonan'));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function penawaranulang(Request $request, $id): JsonResponse
|
public function penawaranulang(Request $request, $id): JsonResponse
|
||||||
|
|||||||
@@ -10,6 +10,7 @@ use Illuminate\Support\Facades\Auth;
|
|||||||
use Illuminate\Support\Facades\Validator;
|
use Illuminate\Support\Facades\Validator;
|
||||||
use Maatwebsite\Excel\Facades\Excel;
|
use Maatwebsite\Excel\Facades\Excel;
|
||||||
use Modules\Lpj\Http\Requests\PersetujuanPenawaranRequest;
|
use Modules\Lpj\Http\Requests\PersetujuanPenawaranRequest;
|
||||||
|
use Modules\Lpj\Models\LaporanExternal;
|
||||||
use Modules\Lpj\Models\PenawaranTender;
|
use Modules\Lpj\Models\PenawaranTender;
|
||||||
use Modules\Lpj\Models\Permohonan;
|
use Modules\Lpj\Models\Permohonan;
|
||||||
use Modules\Lpj\Models\PersetujuanPenawaran;
|
use Modules\Lpj\Models\PersetujuanPenawaran;
|
||||||
@@ -235,6 +236,13 @@ class PembayaranController extends Controller
|
|||||||
'updated_by' => Auth::id(),
|
'updated_by' => Auth::id(),
|
||||||
'updated_at' => now(),
|
'updated_at' => now(),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
LaporanExternal::create([
|
||||||
|
'permohonan_id' => $permohonan->id,
|
||||||
|
'nomor_laporan' => $permohonan->nomor_registrasi,
|
||||||
|
'tanggal_laporan' => now(),
|
||||||
|
'created_by' => Auth::id(),
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -153,7 +153,6 @@ class RegistrasiController extends Controller
|
|||||||
if ($tindakan == 0) {
|
if ($tindakan == 0) {
|
||||||
$dataku['jenis_penilaian_id'] = $request->jenis_penilaian;
|
$dataku['jenis_penilaian_id'] = $request->jenis_penilaian;
|
||||||
$dataku['region_id'] = $request->region;
|
$dataku['region_id'] = $request->region;
|
||||||
$dataku['sla'] = $request->sla;
|
|
||||||
$dataku['status'] = 'registered';
|
$dataku['status'] = 'registered';
|
||||||
if ($request->catatan2) {
|
if ($request->catatan2) {
|
||||||
$dataku['registrasi_catatan'] = $request->catatan2;
|
$dataku['registrasi_catatan'] = $request->catatan2;
|
||||||
@@ -209,11 +208,7 @@ class RegistrasiController extends Controller
|
|||||||
if (1 == $jenis_penilaian) {
|
if (1 == $jenis_penilaian) {
|
||||||
$validateIt['region'] = ['required'];
|
$validateIt['region'] = ['required'];
|
||||||
$messageIt ['region.required'] = 'Silahkan pilih Region';
|
$messageIt ['region.required'] = 'Silahkan pilih Region';
|
||||||
} else {
|
|
||||||
$validateIt['sla'] = ['required'];
|
|
||||||
$messageIt ['sla.required'] = 'Silahkan isi SLA';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} elseif ($tindakan == 1) {
|
} elseif ($tindakan == 1) {
|
||||||
$validateIt['catatan'] = ['required'];
|
$validateIt['catatan'] = ['required'];
|
||||||
$messageIt ['catatan.required'] = 'Silahkan isi Catatan';
|
$messageIt ['catatan.required'] = 'Silahkan isi Catatan';
|
||||||
|
|||||||
@@ -158,7 +158,7 @@ use Illuminate\Support\Facades\Auth;
|
|||||||
$penawaran->jenis_laporan_name = $penawaran->jenisLaporan->name;
|
$penawaran->jenis_laporan_name = $penawaran->jenisLaporan->name;
|
||||||
$penawaran->jenis_laporan_code = $penawaran->jenisLaporan->code;
|
$penawaran->jenis_laporan_code = $penawaran->jenisLaporan->code;
|
||||||
$penawaran->tujuan_penilaian_kjpp_name = $penawaran->tujuanPenilaianKjpp->name;
|
$penawaran->tujuan_penilaian_kjpp_name = $penawaran->tujuanPenilaianKjpp->name;
|
||||||
$penawaran->penilaian_waktu_penilain = $penawaran->penilaian->waktu_penilaian;
|
$penawaran->penilaian_waktu_penilain = $penawaran->penilaian->waktu_penilaian ?? "";
|
||||||
|
|
||||||
$permohonan = Permohonan::where('nomor_registrasi','=',$penawaran->nomor_registrasi)
|
$permohonan = Permohonan::where('nomor_registrasi','=',$penawaran->nomor_registrasi)
|
||||||
->leftJoin('dokumen_jaminan', 'dokumen_jaminan.permohonan_id','=','permohonan.id')
|
->leftJoin('dokumen_jaminan', 'dokumen_jaminan.permohonan_id','=','permohonan.id')
|
||||||
@@ -244,7 +244,7 @@ use Illuminate\Support\Facades\Auth;
|
|||||||
$penawaran->jenis_laporan_name = $penawaran->jenisLaporan->name;
|
$penawaran->jenis_laporan_name = $penawaran->jenisLaporan->name;
|
||||||
$penawaran->jenis_laporan_code = $penawaran->jenisLaporan->code;
|
$penawaran->jenis_laporan_code = $penawaran->jenisLaporan->code;
|
||||||
$penawaran->tujuan_penilaian_kjpp_name = $penawaran->tujuanPenilaianKjpp->name;
|
$penawaran->tujuan_penilaian_kjpp_name = $penawaran->tujuanPenilaianKjpp->name;
|
||||||
$penawaran->penilaian_waktu_penilain = $penawaran->penilaian->waktu_penilaian;
|
$penawaran->penilaian_waktu_penilain = $penawaran->penilaian->waktu_penilaian ?? "";
|
||||||
|
|
||||||
$permohonan = Permohonan::where('nomor_registrasi','=',$penawaran->nomor_registrasi)
|
$permohonan = Permohonan::where('nomor_registrasi','=',$penawaran->nomor_registrasi)
|
||||||
->leftJoin('dokumen_jaminan', 'dokumen_jaminan.permohonan_id','=','permohonan.id')
|
->leftJoin('dokumen_jaminan', 'dokumen_jaminan.permohonan_id','=','permohonan.id')
|
||||||
|
|||||||
41
app/Http/Requests/LaporanExternalRequest.php
Normal file
41
app/Http/Requests/LaporanExternalRequest.php
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Http\Requests;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Http\FormRequest;
|
||||||
|
|
||||||
|
class LaporanExternalRequest extends FormRequest
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Get the validation rules that apply to the request.
|
||||||
|
*/
|
||||||
|
public function rules()
|
||||||
|
: array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'permohonan_id' => 'required|exists:permohonan,id',
|
||||||
|
'nomor_laporan' => 'nullable|string|max:255',
|
||||||
|
'tgl_final_laporan' => 'nullable|date',
|
||||||
|
'nilai_pasar' => 'nullable|numeric',
|
||||||
|
'indikasi_nilai_likuidasi' => 'nullable|numeric',
|
||||||
|
'indikasi_nilai_pasar_tanah' => 'nullable|numeric',
|
||||||
|
'estimasi_harga_tanah' => 'nullable|numeric',
|
||||||
|
'estimasi_harga_bangunan' => 'nullable|numeric',
|
||||||
|
'indikasi_nilai_pasar_bangunan' => 'nullable|numeric',
|
||||||
|
'indikasi_nilai_pasar_sarana_pelengkap' => 'nullable|numeric',
|
||||||
|
'indikasi_nilai_pasar_mesin' => 'nullable|numeric',
|
||||||
|
'indikasi_nilai_pasar_kendaraan_alat_berat' => 'nullable|numeric',
|
||||||
|
'file_resume' => 'nullable|file|mimes:pdf|max:10240', // 10MB max
|
||||||
|
'file_laporan' => 'nullable|file|mimes:pdf|max:10240',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determine if the user is authorized to make this request.
|
||||||
|
*/
|
||||||
|
public function authorize()
|
||||||
|
: bool
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
32
app/Models/LaporanExternal.php
Normal file
32
app/Models/LaporanExternal.php
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Models;
|
||||||
|
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
|
// use Modules\Lpj\Database\Factories\LaporanExternalFactory;
|
||||||
|
|
||||||
|
class LaporanExternal extends Base
|
||||||
|
{
|
||||||
|
protected $fillable = [
|
||||||
|
'permohonan_id',
|
||||||
|
'nomor_laporan',
|
||||||
|
'tgl_final_laporan',
|
||||||
|
'nilai_pasar',
|
||||||
|
'indikasi_nilai_likuidasi',
|
||||||
|
'indikasi_nilai_pasar_tanah',
|
||||||
|
'estimasi_harga_tanah',
|
||||||
|
'estimasi_harga_bangunan',
|
||||||
|
'indikasi_nilai_pasar_bangunan',
|
||||||
|
'indikasi_nilai_pasar_sarana_pelengkap',
|
||||||
|
'indikasi_nilai_pasar_mesin',
|
||||||
|
'indikasi_nilai_pasar_kendaraan_alat_berat',
|
||||||
|
'file_resume',
|
||||||
|
'file_laporan',
|
||||||
|
];
|
||||||
|
|
||||||
|
public function permohonan()
|
||||||
|
{
|
||||||
|
return $this->belongsTo(Permohonan::class);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,47 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
use Modules\Lpj\Models\Permohonan;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
Schema::create('laporan_externals', function (Blueprint $table) {
|
||||||
|
$table->id();
|
||||||
|
$table->foreignIdFor(Permohonan::class)->constrained('permohonan')->onDelete('cascade');
|
||||||
|
$table->string('nomor_laporan');
|
||||||
|
$table->date('tgl_final_laporan')->nullable();
|
||||||
|
$table->decimal('nilai_pasar', 15, 2)->nullable();
|
||||||
|
$table->decimal('indikasi_nilai_likuidasi', 15, 2)->nullable();
|
||||||
|
$table->decimal('indikasi_nilai_pasar_tanah', 15, 2)->nullable();
|
||||||
|
$table->decimal('estimasi_harga_tanah', 15, 2)->nullable();
|
||||||
|
$table->decimal('estimasi_harga_bangunan', 15, 2)->nullable();
|
||||||
|
$table->decimal('indikasi_nilai_pasar_bangunan', 15, 2)->nullable();
|
||||||
|
$table->decimal('indikasi_nilai_pasar_sarana_pelengkap', 15, 2)->nullable();
|
||||||
|
$table->decimal('indikasi_nilai_pasar_mesin', 15, 2)->nullable();
|
||||||
|
$table->decimal('indikasi_nilai_pasar_kendaraan_alat_berat', 15, 2)->nullable();
|
||||||
|
$table->string('file_resume')->nullable(); // New field for resume file
|
||||||
|
$table->string('file_laporan')->nullable(); // New field for report file
|
||||||
|
$table->timestamps();
|
||||||
|
$table->softDeletes();
|
||||||
|
|
||||||
|
$table->unsignedBigInteger('created_by')->nullable();
|
||||||
|
$table->unsignedBigInteger('updated_by')->nullable();
|
||||||
|
$table->unsignedBigInteger('deleted_by')->nullable();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::dropIfExists('laporan_externals');
|
||||||
|
}
|
||||||
|
};
|
||||||
12
module.json
12
module.json
@@ -218,6 +218,18 @@
|
|||||||
"admin"
|
"admin"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"title": "Laporan External",
|
||||||
|
"path": "laporan-external",
|
||||||
|
"icon": "ki-filled ki-document text-lg text-primary",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": [
|
||||||
|
"administrator",
|
||||||
|
"admin"
|
||||||
|
]
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"title": "Registrasi Final",
|
"title": "Registrasi Final",
|
||||||
"path": "registrasifinal",
|
"path": "registrasifinal",
|
||||||
|
|||||||
@@ -50,6 +50,26 @@
|
|||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@if(isset($penawaran))
|
||||||
|
<div class="mb-5">
|
||||||
|
<h3 class="text-md font-medium text-gray-900">
|
||||||
|
Nomor Penawaran:
|
||||||
|
</h3>
|
||||||
|
<span class="text-2sm text-gray-700">
|
||||||
|
{{ $penawaran->code }}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-5">
|
||||||
|
<h3 class="text-md font-medium text-gray-900">
|
||||||
|
Nomor Penawaran:
|
||||||
|
</h3>
|
||||||
|
<span class="text-2sm text-gray-700">
|
||||||
|
{{ $penawaran->tujuanPenilaianKjpp->name }}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
@else
|
||||||
|
|
||||||
<div class="mb-5">
|
<div class="mb-5">
|
||||||
<h3 class="text-md font-medium text-gray-900">
|
<h3 class="text-md font-medium text-gray-900">
|
||||||
Tujan Permohonan:
|
Tujan Permohonan:
|
||||||
@@ -77,6 +97,7 @@
|
|||||||
{{ str_replace('_', ' ', $permohonan->status_bayar) }}
|
{{ str_replace('_', ' ', $permohonan->status_bayar) }}
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
@endif
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -237,12 +258,7 @@
|
|||||||
Alamat Jaminan:
|
Alamat Jaminan:
|
||||||
</h3>
|
</h3>
|
||||||
<span class="text-2sm text-gray-700">
|
<span class="text-2sm text-gray-700">
|
||||||
{{ $dokumen->pemilik->address ?? '' }},
|
{{ formatAlamat($dokumen) }}
|
||||||
<br> {{ $dokumen->pemilik->village->name ?? '' }},
|
|
||||||
{{ $dokumen->pemilik->district->name ?? '' }},
|
|
||||||
{{ $dokumen->pemilik->city->name ?? '' }},
|
|
||||||
{{ $dokumen->pemilik->province->name ?? '' }} -
|
|
||||||
{{ $dokumen->pemilik->village->postal_code ?? '' }}
|
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -262,7 +262,16 @@
|
|||||||
<label class="form-label max-w-56 font-bold">
|
<label class="form-label max-w-56 font-bold">
|
||||||
{{ $n + 1 }}. {{ $detail->jenisLegalitasJaminan->name }}
|
{{ $n + 1 }}. {{ $detail->jenisLegalitasJaminan->name }}
|
||||||
</label>
|
</label>
|
||||||
<input type="hidden" name="jenis_legalitas_jaminan_id[]" value=" {{ $detail->jenis_legalitas_jaminan_id }}">
|
<input type="hidden" name="jenis_legalitas_jaminan_id[]" value="{{ $detail->jenis_legalitas_jaminan_id }}">
|
||||||
|
<button type="button" class="btn btn-danger btn-sm" onclick="clearDetail({{ $detail->id }})">
|
||||||
|
<i class="ki-duotone ki-trash-square fs-2">
|
||||||
|
<span class="path1"></span>
|
||||||
|
<span class="path2"></span>
|
||||||
|
<span class="path3"></span>
|
||||||
|
<span class="path4"></span>
|
||||||
|
</i>
|
||||||
|
Reset
|
||||||
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
@@ -713,5 +722,75 @@
|
|||||||
return `<input class="input" type="text" name="custom_field[${itemId}][${fieldName}]" value="${value}">`;
|
return `<input class="input" type="text" name="custom_field[${itemId}][${fieldName}]" value="${value}">`;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function clearDetail(detailId) {
|
||||||
|
Swal.fire({
|
||||||
|
title: 'Apakah Anda yakin?',
|
||||||
|
text: "Anda akan menghapus detail ini!",
|
||||||
|
icon: 'warning',
|
||||||
|
showCancelButton: true,
|
||||||
|
confirmButtonColor: '#3085d6',
|
||||||
|
cancelButtonColor: '#d33',
|
||||||
|
confirmButtonText: 'Ya, yakin!',
|
||||||
|
cancelButtonText: 'Batal'
|
||||||
|
}).then((result) => {
|
||||||
|
if (result.isConfirmed) {
|
||||||
|
Swal.fire({
|
||||||
|
title: 'Apakah Anda yakin?',
|
||||||
|
text: "Data yang telah di hapus tidak dapat di kembalikan",
|
||||||
|
icon: 'warning',
|
||||||
|
showCancelButton: true,
|
||||||
|
confirmButtonColor: '#3085d6',
|
||||||
|
cancelButtonColor: '#d33',
|
||||||
|
confirmButtonText: 'Ya, hapus!',
|
||||||
|
cancelButtonText: 'Batal'
|
||||||
|
}).then((result2) => {
|
||||||
|
if (result2.isConfirmed) {
|
||||||
|
// Hapus input fields
|
||||||
|
$(`input[name="detail_dokumen_jaminan_id[]"][value="${detailId}"]`).closest('.grid.gap-5').remove();
|
||||||
|
|
||||||
|
// Kirim request AJAX untuk menghapus data dari database
|
||||||
|
$.ajax({
|
||||||
|
url: '{{ route("debitur.jaminan.clearDetail", $debitur->id ) }}',
|
||||||
|
type: 'POST',
|
||||||
|
data: {
|
||||||
|
_token: '{{ csrf_token() }}',
|
||||||
|
detail_id: detailId
|
||||||
|
},
|
||||||
|
success: function (response) {
|
||||||
|
if (response.success) {
|
||||||
|
Swal.fire({
|
||||||
|
title: 'Berhasil!',
|
||||||
|
text: 'Detail berhasil dihapus',
|
||||||
|
icon: 'success',
|
||||||
|
confirmButtonText: 'OK'
|
||||||
|
}).then((result) => {
|
||||||
|
if (result.isConfirmed) {
|
||||||
|
location.reload();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
Swal.fire({
|
||||||
|
title: 'Gagal!',
|
||||||
|
text: 'Detail gagal dihapus',
|
||||||
|
icon: 'error',
|
||||||
|
confirmButtonText: 'OK'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
error: function () {
|
||||||
|
Swal.fire({
|
||||||
|
title: 'Gagal!',
|
||||||
|
text: 'Terjadi kesalahan saat menghapus detail',
|
||||||
|
icon: 'error',
|
||||||
|
confirmButtonText: 'OK'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
@endpush
|
@endpush
|
||||||
|
|||||||
167
resources/views/laporan_external/create.blade.php
Normal file
167
resources/views/laporan_external/create.blade.php
Normal file
@@ -0,0 +1,167 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render(request()->route()->getName()) }}
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||||
|
<form method="POST" action="{{ isset($laporanExternal) ? route('laporan-external.update', $laporanExternal->id) : route('laporan-external.store') }}" enctype="multipart/form-data">
|
||||||
|
@csrf
|
||||||
|
@if(isset($laporanExternal))
|
||||||
|
@method('PUT')
|
||||||
|
@endif
|
||||||
|
<div class="card border border-agi-100 pb-2.5">
|
||||||
|
<div class="card-header bg-agi-50" id="basic_settings">
|
||||||
|
<h3 class="card-title">
|
||||||
|
{{ isset($laporanExternal) ? 'Edit' : 'Tambah' }} Laporan External
|
||||||
|
</h3>
|
||||||
|
<div class="flex items-center gap-2">
|
||||||
|
<a href="{{ route('laporan-external.index') }}" class="btn btn-xs btn-info"><i class="ki-filled ki-exit-left"></i> Back</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="card-body grid gap-5">
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">Permohonan ID</label>
|
||||||
|
<input type="hidden" name="permohonan_id" value="{{ $laporanExternal->permohonan_id ?? "" }}">
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<strong>{{ $permohonan->nomor_registrasi }}</strong>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">Nomor Laporan</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('nomor_laporan') border-danger bg-danger-light @enderror" type="text" name="nomor_laporan" value="{{ old('nomor_laporan', $laporanExternal->nomor_laporan ?? '') }}">
|
||||||
|
@error('nomor_laporan')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">Tanggal Final Laporan</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('tgl_final_laporan') border-danger bg-danger-light @enderror" type="date" name="tgl_final_laporan" value="{{ old('tgl_final_laporan', $laporanExternal->tgl_final_laporan ?? '') }}">
|
||||||
|
@error('tgl_final_laporan')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">Nilai Pasar</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('nilai_pasar') border-danger bg-danger-light @enderror" type="number" name="nilai_pasar" value="{{ old('nilai_pasar', $laporanExternal->nilai_pasar ?? '') }}">
|
||||||
|
@error('nilai_pasar')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">Indikasi Nilai Likuidasi</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('indikasi_nilai_likuidasi') border-danger bg-danger-light @enderror" type="number" name="indikasi_nilai_likuidasi" value="{{ old('indikasi_nilai_likuidasi', $laporanExternal->indikasi_nilai_likuidasi ?? '') }}">
|
||||||
|
@error('indikasi_nilai_likuidasi')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">Indikasi Nilai Pasar Tanah</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('indikasi_nilai_pasar_tanah') border-danger bg-danger-light @enderror" type="number" name="indikasi_nilai_pasar_tanah" value="{{ old('indikasi_nilai_pasar_tanah', $laporanExternal->indikasi_nilai_pasar_tanah ?? '') }}">
|
||||||
|
@error('indikasi_nilai_pasar_tanah')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">Estimasi Harga Tanah</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('estimasi_harga_tanah') border-danger bg-danger-light @enderror" type="number" name="estimasi_harga_tanah" value="{{ old('estimasi_harga_tanah', $laporanExternal->estimasi_harga_tanah ?? '') }}">
|
||||||
|
@error('estimasi_harga_tanah')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">Estimasi Harga Bangunan</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('estimasi_harga_bangunan') border-danger bg-danger-light @enderror" type="number" name="estimasi_harga_bangunan" value="{{ old('estimasi_harga_bangunan', $laporanExternal->estimasi_harga_bangunan ?? '') }}">
|
||||||
|
@error('estimasi_harga_bangunan')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">Indikasi Nilai Pasar Bangunan</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('indikasi_nilai_pasar_bangunan') border-danger bg-danger-light @enderror" type="number" name="indikasi_nilai_pasar_bangunan" value="{{ old('indikasi_nilai_pasar_bangunan', $laporanExternal->indikasi_nilai_pasar_bangunan ?? '') }}">
|
||||||
|
@error('indikasi_nilai_pasar_bangunan')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">Indikasi Nilai Pasar Sarana Pelengkap</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('indikasi_nilai_pasar_sarana_pelengkap') border-danger bg-danger-light @enderror" type="number" name="indikasi_nilai_pasar_sarana_pelengkap" value="{{ old('indikasi_nilai_pasar_sarana_pelengkap', $laporanExternal->indikasi_nilai_pasar_sarana_pelengkap ?? '') }}">
|
||||||
|
@error('indikasi_nilai_pasar_sarana_pelengkap')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">Indikasi Nilai Pasar Mesin</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('indikasi_nilai_pasar_mesin') border-danger bg-danger-light @enderror" type="number" name="indikasi_nilai_pasar_mesin" value="{{ old('indikasi_nilai_pasar_mesin', $laporanExternal->indikasi_nilai_pasar_mesin ?? '') }}">
|
||||||
|
@error('indikasi_nilai_pasar_mesin')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">Indikasi Nilai Pasar Kendaraan/Alat Berat</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('indikasi_nilai_pasar_kendaraan_alat_berat') border-danger bg-danger-light @enderror" type="number" name="indikasi_nilai_pasar_kendaraan_alat_berat" value="{{ old('indikasi_nilai_pasar_kendaraan_alat_berat', $laporanExternal->indikasi_nilai_pasar_kendaraan_alat_berat ?? '') }}">
|
||||||
|
@error('indikasi_nilai_pasar_kendaraan_alat_berat')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">File Resume</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('file_resume') border-danger bg-danger-light @enderror" type="file" name="file_resume">
|
||||||
|
@if(isset($laporanExternal) && $laporanExternal->file_resume)
|
||||||
|
<p class="mt-2">File saat ini: <p class="mt-2">File saat ini: <a href="storage/{{ $laporanExternal->file_resume }}" download="{{ $laporanExternal->file_resume }}" target="_blank" class="badge badge-sm badge-outline">
|
||||||
|
{{ basename($laporanExternal->file_resume) }} <i class="ki-filled ki-cloud-download"></i>
|
||||||
|
</a></p></p>
|
||||||
|
@endif
|
||||||
|
@error('file_resume')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">File Laporan</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<input class="input @error('file_laporan') border-danger bg-danger-light @enderror" type="file" name="file_laporan">
|
||||||
|
@if(isset($laporanExternal) && $laporanExternal->file_laporan)
|
||||||
|
<p class="mt-2">File saat ini: <a href="storage/{{ $laporanExternal->file_laporan }}" download="{{ $laporanExternal->file_laporan }}" target="_blank" class="badge badge-sm badge-outline">
|
||||||
|
{{ basename($laporanExternal->file_laporan) }} <i class="ki-filled ki-cloud-download"></i>
|
||||||
|
</a></p>
|
||||||
|
@endif
|
||||||
|
@error('file_laporan')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div class="card-footer flex justify-end">
|
||||||
|
<button type="submit" class="btn btn-primary">{{ isset($laporanExternal) ? 'Update' : 'Simpan' }}</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
@endsection
|
||||||
223
resources/views/laporan_external/index.blade.php
Normal file
223
resources/views/laporan_external/index.blade.php
Normal file
@@ -0,0 +1,223 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render('laporan-external') }}
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<div class="grid">
|
||||||
|
<div class="card border border-agi-100 card-grid min-w-full" data-datatable="false" data-datatable-page-size="10" data-datatable-state-save="false" id="laporan-external-table" data-api-url="{{ route('laporan-external.datatables') }}">
|
||||||
|
<div class="card-header bg-agi-50 py-5 flex-wrap">
|
||||||
|
<h3 class="card-title">
|
||||||
|
Daftar Laporan External
|
||||||
|
</h3>
|
||||||
|
<div class="flex flex-wrap gap-2 lg:gap-5">
|
||||||
|
<div class="flex">
|
||||||
|
<label class="input input-sm"> <i class="ki-filled ki-magnifier"> </i>
|
||||||
|
<input placeholder="Search Laporan External" id="search" type="text" value="">
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-wrap gap-2.5 hidden">
|
||||||
|
<div class="h-[24px] border border-r-gray-200"></div>
|
||||||
|
<a class="btn btn-sm btn-light" href="{{ route('laporan-external.export') }}"> Export to Excel </a>
|
||||||
|
<a class="btn btn-sm btn-primary" href="{{ route('laporan-external.create') }}"> Tambah Laporan External </a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="scrollable-x-auto">
|
||||||
|
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm" data-datatable-table="true">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="w-14">
|
||||||
|
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox"/>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nomor_laporan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nomor Laporan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tgl_final_laporan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Final Laporan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="nilai_pasar">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nilai Pasar </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="indikasi_nilai_likuidasi">
|
||||||
|
<span class="sort"> <span class="sort-label"> Indikasi Nilai Likuidasi </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="indikasi_nilai_pasar_tanah">
|
||||||
|
<span class="sort"> <span class="sort-label"> Indikasi Nilai Pasar Tanah </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="estimasi_harga_bangunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Estimasi Harga Bangunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="indikasi_nilai_pasar_bangunan">
|
||||||
|
<span class="sort"> <span class="sort-label"> Indikasi Nilai Pasar Bangunan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="indikasi_nilai_pasar_sarana_pelengkap">
|
||||||
|
<span class="sort"> <span class="sort-label"> Indikasi Nilai Pasar Sarana Pelengkap </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="indikasi_nilai_pasar_mesin">
|
||||||
|
<span class="sort"> <span class="sort-label"> Indikasi Nilai Pasar Mesin </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="indikasi_nilai_pasar_kendaraan_alat_berat">
|
||||||
|
<span class="sort"> <span class="sort-label"> Indikasi Nilai Pasar Kendaraan/Alat Berat </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="file_resume">
|
||||||
|
<span class="sort"> <span class="sort-label"> File Resume </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="file_laporan">
|
||||||
|
<span class="sort"> <span class="sort-label"> File Laporan </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[50px] text-center" data-datatable-column="actions">Action</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
<div class="card-footer justify-center md:justify-between flex-col md:flex-row gap-3 text-gray-600 text-2sm font-medium">
|
||||||
|
<div class="flex items-center gap-2">
|
||||||
|
Show
|
||||||
|
<select class="select select-sm w-16" data-datatable-size="true" name="perpage"> </select> per page
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center gap-4">
|
||||||
|
<span data-datatable-info="true"> </span>
|
||||||
|
<div class="pagination" data-datatable-pagination="true">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@push('scripts')
|
||||||
|
<script type="text/javascript">
|
||||||
|
function deleteData(data) {
|
||||||
|
Swal.fire({
|
||||||
|
title: 'Are you sure?',
|
||||||
|
text: "You won't be able to revert this!",
|
||||||
|
icon: 'warning',
|
||||||
|
showCancelButton: true,
|
||||||
|
confirmButtonColor: '#3085d6',
|
||||||
|
cancelButtonColor: '#d33',
|
||||||
|
confirmButtonText: 'Yes, delete it!'
|
||||||
|
}).then((result) => {
|
||||||
|
if (result.isConfirmed) {
|
||||||
|
$.ajaxSetup({
|
||||||
|
headers: {
|
||||||
|
'X-CSRF-TOKEN': '{{ csrf_token() }}'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$.ajax(`laporan-external/${data}`, {
|
||||||
|
type: 'DELETE'
|
||||||
|
}).then((response) => {
|
||||||
|
swal.fire('Deleted!', 'Laporan External has been deleted.', 'success').then(() => {
|
||||||
|
window.location.reload();
|
||||||
|
});
|
||||||
|
}).catch((error) => {
|
||||||
|
console.error('Error:', error);
|
||||||
|
Swal.fire('Error!', 'An error occurred while deleting the laporan.', 'error');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
<script type="module">
|
||||||
|
const element = document.querySelector('#laporan-external-table');
|
||||||
|
const searchInput = document.getElementById('search');
|
||||||
|
|
||||||
|
const apiUrl = element.getAttribute('data-api-url');
|
||||||
|
const dataTableOptions = {
|
||||||
|
apiEndpoint: apiUrl,
|
||||||
|
pageSize: 5,
|
||||||
|
columns: {
|
||||||
|
select: {
|
||||||
|
render: (item, data, context) => {
|
||||||
|
const checkbox = document.createElement('input');
|
||||||
|
checkbox.className = 'checkbox checkbox-sm';
|
||||||
|
checkbox.type = 'checkbox';
|
||||||
|
checkbox.value = data.id.toString();
|
||||||
|
checkbox.setAttribute('data-datatable-row-check', 'true');
|
||||||
|
return checkbox.outerHTML.trim();
|
||||||
|
},
|
||||||
|
},
|
||||||
|
nomor_laporan: {
|
||||||
|
title: 'Nomor Laporan',
|
||||||
|
},
|
||||||
|
tgl_final_laporan: {
|
||||||
|
title: 'Tanggal Final Laporan',
|
||||||
|
},
|
||||||
|
nilai_pasar: {
|
||||||
|
title: 'Nilai Pasar',
|
||||||
|
},
|
||||||
|
indikasi_nilai_likuidasi: {
|
||||||
|
title: 'Indikasi Nilai Likuidasi',
|
||||||
|
},
|
||||||
|
indikasi_nilai_pasar_tanah: {
|
||||||
|
title: 'Indikasi Nilai Pasar Tanah',
|
||||||
|
},
|
||||||
|
estimasi_harga_bangunan: {
|
||||||
|
title: 'Estimasi Harga Bangunan',
|
||||||
|
},
|
||||||
|
indikasi_nilai_pasar_bangunan: {
|
||||||
|
title: 'Indikasi Nilai Pasar Bangunan',
|
||||||
|
},
|
||||||
|
indikasi_nilai_pasar_sarana_pelengkap: {
|
||||||
|
title: 'Indikasi Nilai Pasar Sarana Pelengkap',
|
||||||
|
},
|
||||||
|
indikasi_nilai_pasar_mesin: {
|
||||||
|
title: 'Indikasi Nilai Pasar Mesin',
|
||||||
|
},
|
||||||
|
indikasi_nilai_pasar_kendaraan_alat_berat: {
|
||||||
|
title: 'Indikasi Nilai Pasar Kendaraan/Alat Berat',
|
||||||
|
},
|
||||||
|
file_resume: {
|
||||||
|
title: 'File Resume',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.file_resume ? `<a href="storage/${data.file_resume}" download="${data.file_resume}" target="_blank" class="badge badge-sm badge-outline">
|
||||||
|
Download <i class="ki-filled ki-cloud-download"></i>
|
||||||
|
</a>` : 'N/A';
|
||||||
|
},
|
||||||
|
},
|
||||||
|
file_laporan: {
|
||||||
|
title: 'File Laporan',
|
||||||
|
render: (item, data) => {
|
||||||
|
return data.file_laporan ? `<a href="storage/${data.file_laporan}" download="${data.file_laporan}" target="_blank" class="badge badge-sm badge-outline">
|
||||||
|
Download <i class="ki-filled ki-cloud-download"></i>
|
||||||
|
</a>` : 'N/A';
|
||||||
|
|
||||||
|
},
|
||||||
|
},
|
||||||
|
actions: {
|
||||||
|
title: 'Action',
|
||||||
|
render: (item, data) => {
|
||||||
|
return `<div class="flex flex-nowrap justify-center">
|
||||||
|
<a class="btn btn-sm btn-icon btn-clear btn-info" href="laporan-external/${data.id}/edit">
|
||||||
|
<i class="ki-outline ki-notepad-edit"></i>
|
||||||
|
</a>
|
||||||
|
</div>`;
|
||||||
|
},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
let dataTable = new KTDataTable(element, dataTableOptions);
|
||||||
|
// Custom search functionality
|
||||||
|
searchInput.addEventListener('input', function () {
|
||||||
|
const searchValue = this.value.trim();
|
||||||
|
dataTable.search(searchValue, true);
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
@endpush
|
||||||
@@ -8,35 +8,19 @@
|
|||||||
@endphp
|
@endphp
|
||||||
@section('content')
|
@section('content')
|
||||||
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||||
<div class="card border border-agi-100 pb-2.5">
|
@php
|
||||||
<div class="card-header bg-agi-50" id="basic_settings">
|
$buttonProses='';
|
||||||
<h3 class="card-title">
|
$buttonProses='<a href="'. route('otorisasitender.penawaran.edit', $id) .'" class="btn btn-xs btn-primary" title="Otorisasi Penawaran"><i class="ki-outline ki-arrow-circle-right"></i> Otorisasi Penawaran</a>';
|
||||||
Detail Data Otorisasi Penawaran
|
@endphp
|
||||||
</h3>
|
|
||||||
<div class="flex items-center gap-2">
|
@include('lpj::component.detail-jaminan', [
|
||||||
<a href="{{ route('otorisasitender.penawaran.edit', $id) }}" class="btn btn-xs btn-primary" title="Register"><i class="ki-filled ki-arrow-circle-right"></i> Otorisasi Penawaran</a>
|
'customlink' => $buttonProses,
|
||||||
<a href="{{ route('otorisasitender.penawaran.index') }}" class="btn btn-xs btn-info"><i class="ki-filled ki-exit-left"></i> Back</a>
|
'backLink' => 'otorisasitender.penawaran.index',
|
||||||
</div>
|
'title' => 'Detail Data Otorisasi Penawaran',
|
||||||
</div>
|
'penawaran' => $prosespenawaran,
|
||||||
<div class="card-body lg:py-7.5 grid grid-cols-3">
|
])
|
||||||
<div class="mb-5">
|
|
||||||
<h3 class="text-md font-medium text-gray-900">
|
|
||||||
Nomor Register Permohonan:
|
|
||||||
</h3>
|
|
||||||
<span class="text-2sm text-gray-700">
|
|
||||||
{{ $prosespenawaran->nomor_registrasi }}
|
|
||||||
</span>
|
|
||||||
</div>
|
|
||||||
<div class="mb-5">
|
|
||||||
<h3 class="text-md font-medium text-gray-900">
|
|
||||||
Nomor Penawaran:
|
|
||||||
</h3>
|
|
||||||
<span class="text-2sm text-gray-700">
|
|
||||||
{{ $prosespenawaran->code }}
|
|
||||||
</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -131,7 +131,7 @@
|
|||||||
<a href="/tender/penawaran/${nomor_registrasi}/edit" class="btn btn-sm btn-icon btn-clear btn-info" title="Penawaran">
|
<a href="/tender/penawaran/${nomor_registrasi}/edit" class="btn btn-sm btn-icon btn-clear btn-info" title="Penawaran">
|
||||||
<i class="ki-outline ki-arrow-circle-right"></i>
|
<i class="ki-outline ki-arrow-circle-right"></i>
|
||||||
</a>
|
</a>
|
||||||
<a href="/tender/penawaran/${nomor_registrasi}/showKirimEmail" class="btn btn-sm btn-icon btn-clear btn-success" title="Kirim Email">
|
<a href="/tender/penawaran/${nomor_registrasi}/showKirimEmail" class="btn btn-sm btn-icon btn-clear btn-success hidden" title="Kirim Email">
|
||||||
<i class="ki-filled ki-paper-plane"></i>
|
<i class="ki-filled ki-paper-plane"></i>
|
||||||
</a>
|
</a>
|
||||||
`;
|
`;
|
||||||
|
|||||||
@@ -72,15 +72,7 @@
|
|||||||
<em id="{{$route[0]}}_catatan_msg" class="alert text-danger text-sm"></em>
|
<em id="{{$route[0]}}_catatan_msg" class="alert text-danger text-sm"></em>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div id="{{ $route[0] }}_div_sla" class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
SLA (dalam satuan hari)
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input class="inputku input" name="{{$route[0]}}_sla" id="{{$route[0]}}_sla" placeholder="dalam satuan hari" type="text" />
|
|
||||||
<em id="{{$route[0]}}_sla_msg" class="alert text-danger text-sm"></em>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div id="{{ $route[0] }}_div_region" class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div id="{{ $route[0] }}_div_region" class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
Region
|
Region
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
@push('scripts')
|
@push('scripts')
|
||||||
@include('lpj::assetsku.includenya')
|
@include('lpj::assetsku.includenya')
|
||||||
<script type="module">
|
<script type="module">
|
||||||
|
|
||||||
$(document).ready(function() {
|
$(document).ready(function() {
|
||||||
prepareForm();
|
prepareForm();
|
||||||
});
|
});
|
||||||
@@ -13,7 +13,6 @@
|
|||||||
$("#{{ $route[0] }}_div_jenis_pilihan").show();
|
$("#{{ $route[0] }}_div_jenis_pilihan").show();
|
||||||
$("#{{ $route[0] }}_div_catatan").hide();
|
$("#{{ $route[0] }}_div_catatan").hide();
|
||||||
$("#{{ $route[0] }}_div_region").hide();
|
$("#{{ $route[0] }}_div_region").hide();
|
||||||
$("#{{ $route[0] }}_div_sla").hide();
|
|
||||||
$("#{{ $route[0] }}_div_catatan2").show();
|
$("#{{ $route[0] }}_div_catatan2").show();
|
||||||
// prepare data
|
// prepare data
|
||||||
setData();
|
setData();
|
||||||
@@ -40,7 +39,7 @@
|
|||||||
// }
|
// }
|
||||||
},
|
},
|
||||||
success: function(response) {
|
success: function(response) {
|
||||||
|
|
||||||
if ('success' == response.status)
|
if ('success' == response.status)
|
||||||
{
|
{
|
||||||
$("#textReg").text(response.datas.nomor_registrasi);
|
$("#textReg").text(response.datas.nomor_registrasi);
|
||||||
@@ -50,7 +49,7 @@
|
|||||||
// success
|
// success
|
||||||
// var message = response.message;
|
// var message = response.message;
|
||||||
// toastrku("success", message);
|
// toastrku("success", message);
|
||||||
|
|
||||||
}
|
}
|
||||||
else if('error' == response.status)
|
else if('error' == response.status)
|
||||||
{
|
{
|
||||||
@@ -96,7 +95,7 @@
|
|||||||
$("#{{ $route[0] }}_div_jenis_pilihan").show();
|
$("#{{ $route[0] }}_div_jenis_pilihan").show();
|
||||||
$("#{{ $route[0] }}_catatan").val('');
|
$("#{{ $route[0] }}_catatan").val('');
|
||||||
$("#{{ $route[0] }}_div_catatan").hide();
|
$("#{{ $route[0] }}_div_catatan").hide();
|
||||||
|
|
||||||
$("#{{ $route[0] }}_div_catatan2").show();
|
$("#{{ $route[0] }}_div_catatan2").show();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -105,7 +104,6 @@
|
|||||||
$("#{{ $route[0] }}_div_jenis_pilihan").hide();
|
$("#{{ $route[0] }}_div_jenis_pilihan").hide();
|
||||||
$("#{{ $route[0] }}_div_catatan").show();
|
$("#{{ $route[0] }}_div_catatan").show();
|
||||||
$("#{{ $route[0] }}_div_catatan2").hide();
|
$("#{{ $route[0] }}_div_catatan2").hide();
|
||||||
$("#{{ $route[0] }}_div_sla").hide();
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -122,7 +120,6 @@
|
|||||||
let region = $("#{{$route[0]}}_region").val();
|
let region = $("#{{$route[0]}}_region").val();
|
||||||
let catatan = $("#{{$route[0]}}_catatan").val();
|
let catatan = $("#{{$route[0]}}_catatan").val();
|
||||||
let catatan2 = $("#{{$route[0]}}_catatan2").val();
|
let catatan2 = $("#{{$route[0]}}_catatan2").val();
|
||||||
let sla = $("#{{$route[0]}}_sla").val();
|
|
||||||
|
|
||||||
if(jenis_penilaian==0)
|
if(jenis_penilaian==0)
|
||||||
jenis_penilaian='';
|
jenis_penilaian='';
|
||||||
@@ -138,7 +135,6 @@
|
|||||||
input_data.region= region;
|
input_data.region= region;
|
||||||
input_data.catatan = catatan;
|
input_data.catatan = catatan;
|
||||||
input_data.catatan2 = catatan2;
|
input_data.catatan2 = catatan2;
|
||||||
input_data.sla = sla;
|
|
||||||
|
|
||||||
let useURL= '{{ route($route[0].'.update', $id) }}';
|
let useURL= '{{ route($route[0].'.update', $id) }}';
|
||||||
$.ajax({
|
$.ajax({
|
||||||
@@ -169,11 +165,7 @@
|
|||||||
$("#{{$route[0]}}_region").addClass(" border-danger");
|
$("#{{$route[0]}}_region").addClass(" border-danger");
|
||||||
$("#{{$route[0]}}_region_msg").text(value);
|
$("#{{$route[0]}}_region_msg").text(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ("sla" === index) {
|
|
||||||
$("#{{$route[0]}}_sla").addClass(" border-danger");
|
|
||||||
$("#{{$route[0]}}_sla_msg").text(value);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -182,7 +174,7 @@
|
|||||||
var message = response.message;
|
var message = response.message;
|
||||||
toastrku("success", message);
|
toastrku("success", message);
|
||||||
|
|
||||||
setTimeout(function () {
|
setTimeout(function () {
|
||||||
var url = "{{ route('registrasi.index') }}";
|
var url = "{{ route('registrasi.index') }}";
|
||||||
$(location).attr('href',url);
|
$(location).attr('href',url);
|
||||||
// window.location.href = "https://www.newurl.com";
|
// window.location.href = "https://www.newurl.com";
|
||||||
@@ -214,18 +206,15 @@
|
|||||||
{
|
{
|
||||||
// INTERNAL, show region
|
// INTERNAL, show region
|
||||||
$("#{{ $route[0] }}_div_region").show();
|
$("#{{ $route[0] }}_div_region").show();
|
||||||
$("#{{ $route[0] }}_div_sla").hide();
|
|
||||||
}
|
}
|
||||||
else if('2' == idNya)
|
else if('2' == idNya)
|
||||||
{
|
{
|
||||||
$("#{{ $route[0] }}_div_sla").show();
|
|
||||||
$("#{{ $route[0] }}_div_region").hide();
|
$("#{{ $route[0] }}_div_region").hide();
|
||||||
}
|
}
|
||||||
else if('0' == idNya)
|
else if('0' == idNya)
|
||||||
{
|
{
|
||||||
// selain INTERNAL, hide region
|
// selain INTERNAL, hide region
|
||||||
$("#{{ $route[0] }}_div_region").hide();
|
$("#{{ $route[0] }}_div_region").hide();
|
||||||
$("#{{ $route[0] }}_div_sla").hide();
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -68,16 +68,7 @@
|
|||||||
<em id="{{ $route[0] }}_catatan_msg" class="alert text-danger text-sm"></em>
|
<em id="{{ $route[0] }}_catatan_msg" class="alert text-danger text-sm"></em>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div id="{{ $route[0] }}_div_sla" class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
SLA (dalam satuan hari)
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input class="inputku input" name="{{ $route[0] }}_sla" id="{{ $route[0] }}_sla"
|
|
||||||
placeholder="dalam satuan hari" type="text" />
|
|
||||||
<em id="{{ $route[0] }}_sla_msg" class="alert text-danger text-sm"></em>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div id="{{ $route[0] }}_div_region"
|
<div id="{{ $route[0] }}_div_region"
|
||||||
class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
<label class="form-label max-w-56">
|
<label class="form-label max-w-56">
|
||||||
|
|||||||
@@ -60,7 +60,7 @@
|
|||||||
</center>
|
</center>
|
||||||
<br>
|
<br>
|
||||||
<h3>Kepada</h3>
|
<h3>Kepada</h3>
|
||||||
<p style="color: red; margin-left:25px">{{ $penawaran->kjpp_name }}</p>
|
<p style="color: red; margin-left:25px">KJPP {{ $penawaran->kjpp_name }}</p>
|
||||||
<p style="color: red; margin-left:25px">{{ $penawaran->kjpp_address }}</p>
|
<p style="color: red; margin-left:25px">{{ $penawaran->kjpp_address }}</p>
|
||||||
<br/>
|
<br/>
|
||||||
<br/>
|
<br/>
|
||||||
@@ -222,7 +222,7 @@
|
|||||||
<table border="0" width="100%">
|
<table border="0" width="100%">
|
||||||
<tr>
|
<tr>
|
||||||
<td width="50%">PT Bank Artha Graha Internasional.<br>Sub Direktorat Appraisal</td>
|
<td width="50%">PT Bank Artha Graha Internasional.<br>Sub Direktorat Appraisal</td>
|
||||||
<td width="50%" align="center"><span style="color: red;">{{ $penawaran->kjpp_name }}</span></td>
|
<td width="50%" align="center"><span style="color: red;">KJPP {{ $penawaran->kjpp_name }}</span></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td colspan="2"><br/></td>
|
<td colspan="2"><br/></td>
|
||||||
@@ -237,8 +237,8 @@
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>
|
<td>
|
||||||
<span style="color: red;">{{ $penawaran->persetujuan_penawaran->creator->name }}</span><br>
|
<span style="color: red;">{{ getUser($penawaran->authorized_by)->name }}</span><br>
|
||||||
<span style="color: red;">{{ $penawaran->persetujuan_penawaran->creator->getRoleNames()[0] }}</span>
|
<span style="color: red;">{{ getUser($penawaran->authorized_by)->getRoleNames()[0] == 'DD Appraisal' ? 'DD Operation 2' : getUser($penawaran->authorized_by)->getRoleNames()[0] }}</span>
|
||||||
</td>
|
</td>
|
||||||
<td align="center">(……………………………………..)</td>
|
<td align="center">(……………………………………..)</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|||||||
@@ -76,7 +76,7 @@
|
|||||||
</center>
|
</center>
|
||||||
<br>
|
<br>
|
||||||
<h3>Kepada</h3>
|
<h3>Kepada</h3>
|
||||||
<p style="color: red; margin-left:25px">{{ $penawaran->kjpp_name }}</p>
|
<p style="color: red; margin-left:25px">KJPP {{ $penawaran->kjpp_name }}</p>
|
||||||
<p style="color: red; margin-left:25px">{{ $penawaran->kjpp_address }}</p>
|
<p style="color: red; margin-left:25px">{{ $penawaran->kjpp_address }}</p>
|
||||||
<br/>
|
<br/>
|
||||||
<br/>
|
<br/>
|
||||||
@@ -243,7 +243,7 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td width="50%">PT Bank Artha Graha Internasional.<br>Sub Direktorat Appraisal</td>
|
<td width="50%">PT Bank Artha Graha Internasional.<br>Sub Direktorat Appraisal</td>
|
||||||
<td width="50%" align="center">
|
<td width="50%" align="center">
|
||||||
<span style="color: red;">{{ $penawaran->kjpp_name }}</span></td>
|
<span style="color: red;">KJPP {{ $penawaran->kjpp_name }}</span></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td colspan="2"><br/></td>
|
<td colspan="2"><br/></td>
|
||||||
@@ -258,8 +258,8 @@
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>
|
<td>
|
||||||
<span style="color: red;">{{ $penawaran->persetujuan_penawaran->creator->name }}</span><br>
|
<span style="color: red;">{{ getUser($penawaran->authorized_by)->name }}</span><br>
|
||||||
<span style="color: red;">{{ $penawaran->persetujuan_penawaran->creator->getRoleNames()[0] }}</span>
|
<span style="color: red;">{{ getUser($penawaran->authorized_by)->getRoleNames()[0] == 'DD Appraisal' ? 'DD Operation 2' : getUser($penawaran->authorized_by)->getRoleNames()[0] }}</span>
|
||||||
</td>
|
</td>
|
||||||
<td align="center">(……………………………………..)</td>
|
<td align="center">(……………………………………..)</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|||||||
@@ -673,10 +673,31 @@ Breadcrumbs::for('noc', function (BreadcrumbTrail $trail) {
|
|||||||
$trail->push('NOC', route('noc.index'));
|
$trail->push('NOC', route('noc.index'));
|
||||||
});
|
});
|
||||||
|
|
||||||
Breadcrumbs::for('noc.edit', function (BreadcrumbTrail $trail) {
|
Breadcrumbs::for('noc.edit', function (BreadcrumbTrail $trail) {
|
||||||
$trail->parent('noc');
|
$trail->parent('noc');
|
||||||
$trail->push('Proses NOC');
|
$trail->push('Proses NOC');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Breadcrumbs::for('laporan-external', function (BreadcrumbTrail $trail) {
|
||||||
|
$trail->push('Laporan External', route('laporan-external.index'));
|
||||||
|
});
|
||||||
|
|
||||||
|
Breadcrumbs::for('laporan-external.show', function (BreadcrumbTrail $trail) {
|
||||||
|
$trail->parent('laporan-external');
|
||||||
|
$trail->push('Show Laporan External');
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
Breadcrumbs::for('laporan-external.create', function (BreadcrumbTrail $trail) {
|
||||||
|
$trail->parent('laporan-external');
|
||||||
|
$trail->push('Tambah Laporan External', route('laporan-external.create'));
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
Breadcrumbs::for('laporan-external.edit', function (BreadcrumbTrail $trail) {
|
||||||
|
$trail->parent('laporan-external');
|
||||||
|
$trail->push('Data Laporan External');
|
||||||
|
});
|
||||||
|
|
||||||
// add andy
|
// add andy
|
||||||
require __DIR__ . '/breadcrumbs_registrasi.php';
|
require __DIR__ . '/breadcrumbs_registrasi.php';
|
||||||
|
|||||||
@@ -17,7 +17,8 @@ use Modules\Lpj\Http\Controllers\JenisLegalitasJaminanController;
|
|||||||
use Modules\Lpj\Http\Controllers\JenisPenilaianController;
|
use Modules\Lpj\Http\Controllers\JenisPenilaianController;
|
||||||
use Modules\Lpj\Http\Controllers\KJPPController;
|
use Modules\Lpj\Http\Controllers\KJPPController;
|
||||||
use Modules\Lpj\Http\Controllers\LaporanController;
|
use Modules\Lpj\Http\Controllers\LaporanController;
|
||||||
use Modules\Lpj\Http\Controllers\NilaiPlafondController;
|
use Modules\Lpj\Http\Controllers\LaporanExternalController;
|
||||||
|
use Modules\Lpj\Http\Controllers\NilaiPlafondController;
|
||||||
use Modules\Lpj\Http\Controllers\NocController;
|
use Modules\Lpj\Http\Controllers\NocController;
|
||||||
use Modules\Lpj\Http\Controllers\PembatalanController;
|
use Modules\Lpj\Http\Controllers\PembatalanController;
|
||||||
use Modules\Lpj\Http\Controllers\PemilikJaminanController;
|
use Modules\Lpj\Http\Controllers\PemilikJaminanController;
|
||||||
@@ -242,7 +243,6 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
Route::get('export', [ArahMataAnginController::class, 'export'])->name('export');
|
Route::get('export', [ArahMataAnginController::class, 'export'])->name('export');
|
||||||
});
|
});
|
||||||
Route::resource('arah-mata-angin', ArahMataAnginController::class);
|
Route::resource('arah-mata-angin', ArahMataAnginController::class);
|
||||||
Route::resource('arah-mata-angin', ArahMataAnginController::class);
|
|
||||||
|
|
||||||
Route::name('status-permohonan.')->prefix('status-permohonan')->group(function () {
|
Route::name('status-permohonan.')->prefix('status-permohonan')->group(function () {
|
||||||
Route::get('restore/{id}', [StatusPermohonanController::class, 'restore'])->name('restore');
|
Route::get('restore/{id}', [StatusPermohonanController::class, 'restore'])->name('restore');
|
||||||
@@ -349,6 +349,8 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
Route::put('{jaminan}', [DokumenJaminanController::class, 'update'])->name('update');
|
Route::put('{jaminan}', [DokumenJaminanController::class, 'update'])->name('update');
|
||||||
Route::post('store', [DokumenJaminanController::class, 'store'])->name('store');
|
Route::post('store', [DokumenJaminanController::class, 'store'])->name('store');
|
||||||
Route::delete('{jaminan}', [DokumenJaminanController::class, 'destroy'])->name('destroy');
|
Route::delete('{jaminan}', [DokumenJaminanController::class, 'destroy'])->name('destroy');
|
||||||
|
|
||||||
|
Route::post('clear-detail', [DokumenJaminanController::class, 'clearDetail'])->name('clearDetail');
|
||||||
});
|
});
|
||||||
|
|
||||||
Route::name('pemilik.')->prefix('{id}/pemilik')->group(function () {
|
Route::name('pemilik.')->prefix('{id}/pemilik')->group(function () {
|
||||||
@@ -631,6 +633,14 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
->name('noc.datatables');
|
->name('noc.datatables');
|
||||||
|
|
||||||
Route::resource('noc', NocController::class);
|
Route::resource('noc', NocController::class);
|
||||||
|
|
||||||
|
Route::name('laporan-external.')->prefix('laporan-external')->group(function () {
|
||||||
|
Route::get('datatables', [LaporanExternalController::class, 'dataForDatatables'])->name('datatables');
|
||||||
|
Route::get('export', [LaporanExternalController::class, 'export'])->name('export');
|
||||||
|
});
|
||||||
|
Route::resource('laporan-external', LaporanExternalController::class);
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
require __DIR__ . '/registrasi.php';
|
require __DIR__ . '/registrasi.php';
|
||||||
|
|||||||
Reference in New Issue
Block a user