2175 lines
81 KiB
PHP
2175 lines
81 KiB
PHP
<?php
|
|
|
|
namespace Modules\Lpj\Http\Controllers;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use Illuminate\Http\RedirectResponse;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Validator;
|
|
use Maatwebsite\Excel\Facades\Excel;
|
|
use Modules\Lpj\Exports\BasicDataSurveyorExport;
|
|
use Illuminate\Support\Facades\DB;
|
|
use Illuminate\Support\Facades\Auth;
|
|
use Illuminate\Support\Facades\Storage;
|
|
use Illuminate\Http\Response;
|
|
use Modules\Lpj\Models\Permohonan;
|
|
use Modules\Lpj\Models\Branch;
|
|
use Modules\Lpj\Models\Surveyor;
|
|
use Modules\Lpj\Models\BentukTanah;
|
|
use Modules\Lpj\Models\KonturTanah;
|
|
use Modules\Location\Models\Province;
|
|
use Modules\Lpj\Models\PosisiKavling;
|
|
use Modules\Lpj\Models\KondisiFisikTanah;
|
|
use Modules\Lpj\Models\KetinggianTanah;
|
|
use Modules\Lpj\Models\SifatBangunan;
|
|
use Modules\Lpj\Models\JenisJaminan;
|
|
use Modules\Lpj\Models\JenisBangunan;
|
|
use Modules\Lpj\Models\KondisiBangunan;
|
|
use Modules\Lpj\Models\SpekBangunan;
|
|
use Modules\Lpj\Models\SpekKategoritBangunan;
|
|
use Modules\Lpj\Models\SaranaPelengkap;
|
|
use Modules\Lpj\Models\ArahMataAngin;
|
|
use Modules\Lpj\Models\Analisa;
|
|
use Modules\Lpj\Models\Penilaian;
|
|
use Modules\Lpj\Models\PerkerasanJalan;
|
|
use Modules\Lpj\Models\AnalisaFakta;
|
|
use Modules\Lpj\Models\AnalisaLingkungan;
|
|
use Modules\Lpj\Models\AnalisaTanahBagunan;
|
|
use Modules\Lpj\Models\SpekBangunanAnalisa;
|
|
use Modules\Lpj\Models\Denah;
|
|
use Modules\Lpj\Models\FotoJaminan;
|
|
use Modules\Lpj\Models\Lingkungan;
|
|
use Modules\Lpj\Models\LantaiUnit;
|
|
use Modules\Lpj\Models\Teams;
|
|
use Modules\Lpj\Models\Lantai;
|
|
use Modules\Lpj\Models\Inspeksi;
|
|
use Modules\Lpj\Models\ViewUnit;
|
|
use Modules\Lpj\Models\JenisUnit;
|
|
use Modules\Lpj\Models\BentukUnit;
|
|
use Modules\Lpj\Models\PosisiUnit;
|
|
use Modules\Lpj\Models\TerletakArea;
|
|
use Modules\Lpj\Models\FasilitasObjek;
|
|
use Modules\Lpj\Models\MerupakanDaerah;
|
|
use Modules\Lpj\Models\ObjekJaminan;
|
|
use Modules\Lpj\Models\ModelAlatBerat;
|
|
use Modules\Lpj\Models\JenisPesawat;
|
|
use Modules\Lpj\Models\DokumenJaminan;
|
|
use Modules\Lpj\Models\DetailDokumenJaminan;
|
|
use Modules\Lpj\Models\JenisKapal;
|
|
use Modules\Lpj\Models\JenisKendaraan;
|
|
use Modules\Lpj\Models\RuteJaminan;
|
|
|
|
use Modules\Lpj\Models\HubunganPemilikJaminan;
|
|
use Modules\Lpj\Models\HubunganPenghuniJaminan;
|
|
use Modules\Lpj\Models\AnalisaUnit;
|
|
use Modules\Lpj\Models\GolonganMasySekitar;
|
|
use Modules\Lpj\Models\TingkatKeramaian;
|
|
use Modules\Lpj\Models\LaluLintasLokasi;
|
|
use Modules\Lpj\Models\SpekBagunanAnalisaDetail;
|
|
use Modules\Lpj\Http\Requests\SurveyorRequest;
|
|
use Modules\Lpj\Http\Requests\FormSurveyorRequest;
|
|
use Modules\Lpj\Emails\SendEmail;
|
|
use Illuminate\Support\Facades\Mail;
|
|
|
|
class SurveyorController extends Controller
|
|
{
|
|
public $user;
|
|
|
|
/**
|
|
* Display a listing of the resource.
|
|
*/
|
|
public function index()
|
|
{
|
|
return view('lpj::surveyor.index');
|
|
}
|
|
|
|
/**
|
|
* Show the specified resource.
|
|
*/
|
|
public function show($id)
|
|
{
|
|
$permohonan = Permohonan::with([
|
|
'user',
|
|
'debiture.province',
|
|
'debiture.city',
|
|
'debiture.district',
|
|
'debiture.village',
|
|
'branch',
|
|
'tujuanPenilaian',
|
|
'penilaian',
|
|
'documents.jenisJaminan',
|
|
])->findOrFail($id);
|
|
|
|
$surveyor = $id;
|
|
$branches = Branch::all();
|
|
$provinces = Province::all();
|
|
$bentukTanah = BentukTanah::all();
|
|
|
|
// Get all inspeksi data for this permohonan
|
|
$inspeksiData = Inspeksi::where('permohonan_id', $id)
|
|
->get()
|
|
->keyBy('jenis_jaminan_id')
|
|
->map(function ($item) {
|
|
return [
|
|
'data_form' => json_decode($item->data_form, true),
|
|
'foto_form' => json_decode($item->foto_form, true),
|
|
'denah_form' => json_decode($item->denah_form, true),
|
|
'data_pembanding' => json_decode($item->data_pembanding, true),
|
|
];
|
|
});
|
|
|
|
|
|
return view('lpj::surveyor.detail', compact(
|
|
'permohonan',
|
|
'surveyor',
|
|
'branches',
|
|
'provinces',
|
|
'bentukTanah',
|
|
'inspeksiData'
|
|
));
|
|
}
|
|
|
|
/**
|
|
* Store form inspeksi.
|
|
*/
|
|
public function store(FormSurveyorRequest $request)
|
|
{
|
|
try {
|
|
// Validate request data
|
|
$validatedData = $request->validated();
|
|
|
|
// Get action specific rules and process data
|
|
$processedData = $this->getActionSpecificRules(
|
|
$validatedData,
|
|
$request->input('type'),
|
|
$request
|
|
);
|
|
|
|
// Find or create inspeksi record
|
|
$inspeksi = Inspeksi::updateOrCreate(
|
|
[
|
|
'permohonan_id' => $request->input('permohonan_id'),
|
|
'jenis_jaminan_id' => $request->input('jenis_jaminan_id')
|
|
],
|
|
[
|
|
'data_form' => json_encode($processedData),
|
|
'name' => $request->input('type')
|
|
]
|
|
);
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => 'Data berhasil disimpan',
|
|
'data' => $processedData
|
|
], 200);
|
|
|
|
} catch (\Exception $e) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => 'Gagal menyimpan data',
|
|
'error' => $e->getMessage()
|
|
], 500);
|
|
}
|
|
}
|
|
|
|
private function getActionSpecificRules($data, $action, $request): array
|
|
{
|
|
$pisah = explode(',', $action);
|
|
|
|
$allRules = [
|
|
'tanah' => $this->getTanahData($data, $request),
|
|
'bangunan' => $this->getBangunanData($data, $request),
|
|
'kapal' => $this->getKapalData($data, $request),
|
|
'kendaraan' => $this->getKendaraanData($data, $request),
|
|
'mesin' => $this->getMesinData($data, $request),
|
|
'pesawat' => $this->getPesawatData($data, $request),
|
|
'alat-berat' => $this->getAlatBeratData($data, $request),
|
|
'apartemen-kantor' => $this->getUnitData($data, $request),
|
|
'lingkungan' => $this->getLingkunganData($data, $request),
|
|
'fakta' => $this->getFactData($data, $request),
|
|
];
|
|
|
|
$rules = [];
|
|
$hasAssetDescriptionRules = false;
|
|
|
|
foreach ($pisah as $act) {
|
|
if (isset($allRules[$act])) {
|
|
$rules = array_merge($rules, $allRules[$act]);
|
|
if ($act == 'tanah' || $act == 'bangunan' || $act == 'apartemen-kantor') {
|
|
$hasAssetDescriptionRules = true;
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($hasAssetDescriptionRules) {
|
|
$rules = array_merge($rules, $this->getAssetData($data));
|
|
}
|
|
|
|
return $rules;
|
|
}
|
|
|
|
|
|
public function storeDenah(Request $request)
|
|
{
|
|
try {
|
|
$validatedData = $request->validate([
|
|
'foto_denah' => 'required|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
|
|
'luas' => 'required|numeric',
|
|
'permohonan_id' => 'required',
|
|
'jenis_jaminan_id' => 'required'
|
|
]);
|
|
|
|
$validatedData['foto_denah'] = $this->uploadFile($request->file('foto_denah'), 'foto_denah');
|
|
|
|
$formatJsonDenah = [
|
|
'foto_denah' => $validatedData['foto_denah'],
|
|
'luas' => $validatedData['luas'],
|
|
];
|
|
|
|
|
|
$inspeksi = Inspeksi::where('permohonan_id', $request->input('permohonan_id'))
|
|
->where('jenis_jaminan_id', $request->input('jenis_jaminan_id'))
|
|
->first();
|
|
|
|
if ($inspeksi) {
|
|
$inspeksi->update([
|
|
'denah_form' => json_encode($formatJsonDenah)
|
|
]);
|
|
} else {
|
|
Inspeksi::create([
|
|
'permohonan_id' => $request->input('permohonan_id'),
|
|
'jenis_jaminan_id' => $request->input('jenis_jaminan_id'),
|
|
'denah_form' => json_encode($formatJsonDenah)
|
|
]);
|
|
}
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => 'Data berhasil disimpan',
|
|
'data' => $formatJsonDenah
|
|
], 200);
|
|
} catch (Exception $e) {
|
|
return response()->json(['success' => false, 'message' => 'Data gagal disimpan: ' . $e->getMessage()], 500);
|
|
}
|
|
}
|
|
|
|
|
|
public function storeFoto(Request $request)
|
|
{
|
|
$validatedData = $this->validateFotoRequest($request);
|
|
try {
|
|
|
|
$photoCategories = [
|
|
'rute_menuju_lokasi' => ['foto_rute', 'name_rute'],
|
|
'object_jaminan' => ['foto_objek', 'name_objek', 'deskripsi_objek'],
|
|
'lingkungan' => ['foto_lingkungan', 'name_lingkungan'],
|
|
'foto_lantai_unit' => ['foto_lantai_unit', 'name_lantai_unit'],
|
|
'foto_lantai_lainnya' => ['foto_lantai_lainnya', 'name_lantai_lainnya'],
|
|
'foto_rute_lainnya' => ['foto_rute_lainnya', 'name_rute_lainnya'],
|
|
];
|
|
|
|
$inspeksi = Inspeksi::firstOrNew([
|
|
'permohonan_id' => $request->input('permohonan_id'),
|
|
'jenis_jaminan_id' => $request->input('jenis_jaminan_id')
|
|
]);
|
|
|
|
// Get existing foto_form data if it exists
|
|
$existingData = $inspeksi->exists && $inspeksi->foto_form
|
|
? json_decode($inspeksi->foto_form, true)
|
|
: [];
|
|
|
|
$formatFotojson = $existingData; // Start with existing data
|
|
|
|
// Process each photo category
|
|
foreach ($photoCategories as $category => $fields) {
|
|
// Only update if new files are provided
|
|
if ($this->categoryHasNewFiles($request, $fields)) {
|
|
// Delete old files for this category only
|
|
if (isset($existingData[$category])) {
|
|
$this->deleteFilesForCategory($existingData[$category]);
|
|
}
|
|
$formatFotojson[$category] = $this->processPhotoCategory($request, $fields);
|
|
}
|
|
}
|
|
|
|
// Process single files
|
|
$singleFiles = ['foto_basement', 'foto_gerbang', 'pendamping'];
|
|
foreach ($singleFiles as $file) {
|
|
if ($request->hasFile($file)) {
|
|
// Delete old file if exists
|
|
if (isset($existingData[$file])) {
|
|
$this->deleteFile($existingData[$file]);
|
|
}
|
|
$formatFotojson[$file] = $this->uploadFile($request->file($file), $file);
|
|
}
|
|
}
|
|
|
|
// Update record
|
|
$inspeksi->foto_form = json_encode($formatFotojson);
|
|
$inspeksi->save();
|
|
|
|
|
|
|
|
return response()->json(['success' => true, 'message' => 'Data berhasil disimpan', 'data' => $formatFotojson], 200);
|
|
} catch (Exception $e) {
|
|
return response()->json(['success' => false, 'message' => 'Failed to upload: ' . $e->getMessage()], 500);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Process a photo category and its subcategories
|
|
*/
|
|
|
|
private function processPhotoCategory(Request $request, array $fields)
|
|
{
|
|
$result = [];
|
|
$photoField = $fields[0];
|
|
|
|
if ($request->hasFile($photoField)) {
|
|
foreach ($request->file($photoField, []) as $key => $value) {
|
|
$item = [];
|
|
$item[$fields[1]] = $request->input($fields[1] . '.' . $key);
|
|
$item[$photoField] = $this->uploadFile($value, $photoField . '.' . $key);
|
|
|
|
if (isset($fields[2])) {
|
|
$item[$fields[2]] = $request->input($fields[2] . '.' . $key);
|
|
}
|
|
|
|
$result[] = $item;
|
|
}
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
private function categoryHasNewFiles(Request $request, array $fields): bool
|
|
{
|
|
$photoField = $fields[0]; // First element is usually the photo field
|
|
return $request->hasFile($photoField) ||
|
|
(is_array($request->file($photoField)) && count($request->file($photoField)) > 0);
|
|
}
|
|
|
|
private function deleteFilesForCategory($categoryData)
|
|
{
|
|
if (!is_array($categoryData)) {
|
|
return;
|
|
}
|
|
|
|
foreach ($categoryData as $item) {
|
|
if (isset($item['foto'])) {
|
|
$this->deleteOfFile($item['foto']);
|
|
}
|
|
}
|
|
}
|
|
|
|
private function deleteOfFile($filePath)
|
|
{
|
|
if ($filePath && Storage::exists($filePath)) {
|
|
Storage::delete($filePath);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
* Custom validation request for foto
|
|
*/
|
|
public function validateFotoRequest(Request $request)
|
|
{
|
|
return $request->validate([
|
|
'permohonan_id' => 'required',
|
|
'jenis_jaminan_id' => 'required',
|
|
'pendamping' => 'nullable|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
|
|
'foto_objek.*' => 'required|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
|
|
'name_objek.*' => 'required|string|max:255',
|
|
'foto_lingkungan.*' => 'required|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
|
|
'name_lingkungan.*' => 'required|string|max:255',
|
|
'foto_rute.*' => 'required|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
|
|
'name_rute.*' => 'required|string|max:255',
|
|
'lantai.*' => 'nullable|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
|
|
'name_lantai_unit.*' => 'nullable|string|max:255',
|
|
'foto_lantai_unit.*' => 'required|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
|
|
'name_rute_lainnya.*' => 'nullable|string',
|
|
'foto_rute_lainnya.*' => 'nullable|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
|
|
'foto_lantai_lainnya.*' => 'nullable|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
|
|
'name_lantai_lainnya.*' => 'nullable|string|max:255',
|
|
'foto_basement.*' => 'nullable|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
|
|
'name_basement.*' => 'nullable|string|max:255',
|
|
'foto_gerbang' => 'nullable|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
|
|
'name_gerbang' => 'nullable|string|max:255',
|
|
]);
|
|
}
|
|
|
|
public function submitSurveyor($id)
|
|
{
|
|
try {
|
|
// Get button status check result
|
|
$buttonStatusCheck = $this->checkButtonStatus($id);
|
|
$buttonStatus = json_decode($buttonStatusCheck->getContent(), true);
|
|
|
|
// Check if button should be disabled
|
|
if ($buttonStatus['buttonDisable']) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => 'Form belum lengkap. Pastikan semua data telah diisi dengan benar.',
|
|
], 422);
|
|
}
|
|
|
|
// If validation passes, update permohonan status
|
|
$permohonan = Permohonan::findOrFail($id);
|
|
$permohonan->update([
|
|
'status' => 'done',
|
|
'submitted_at' => now()
|
|
]);
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => 'Form surveyor berhasil disubmit'
|
|
], 200);
|
|
|
|
} catch (\Exception $e) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => 'Terjadi kesalahan',
|
|
'error' => $e->getMessage()
|
|
], 500);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
public function checkButtonStatus($id)
|
|
{
|
|
try {
|
|
// Get all inspeksi records for this permohonan
|
|
$inspeksiRecords = Inspeksi::where('permohonan_id', $id)->get();
|
|
|
|
if ($inspeksiRecords->isEmpty()) {
|
|
return response()->json(['buttonDisable' => true]);
|
|
}
|
|
|
|
foreach ($inspeksiRecords as $inspeksi) {
|
|
$dataForm = json_decode($inspeksi->data_form, true);
|
|
$fotoForm = json_decode($inspeksi->foto_form, true);
|
|
$denahForm = json_decode($inspeksi->denah_form, true);
|
|
$dataPembanding = json_decode($inspeksi->data_pembanding, true);
|
|
|
|
// Get jenis jaminan to check if it needs denah
|
|
$jenisJaminan = JenisJaminan::find($inspeksi->jenis_jaminan_id);
|
|
$isTanahBangunan = !in_array(
|
|
strtoupper($jenisJaminan->name ?? ''),
|
|
['KAPAL', 'PESAWAT', 'KENDARAAN', 'ALAT BERAT']
|
|
);
|
|
|
|
// Check if required forms are empty or incomplete
|
|
if (empty($dataForm) || empty($fotoForm)) {
|
|
return response()->json(['buttonDisable' => true]);
|
|
}
|
|
|
|
if ($isTanahBangunan && empty($denahForm)) {
|
|
return response()->json(['buttonDisable' => true]);
|
|
}
|
|
|
|
if (empty($dataPembanding)) {
|
|
return response()->json(['buttonDisable' => true]);
|
|
}
|
|
}
|
|
|
|
// If we get here, all checks passed
|
|
return response()->json(['buttonDisable' => false]);
|
|
|
|
} catch (\Exception $e) {
|
|
return response()->json([
|
|
'error' => 'Something went wrong',
|
|
'message' => $e->getMessage(),
|
|
'buttonDisable' => true
|
|
], 500);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
public function storeJadwal(Request $request)
|
|
{
|
|
try {
|
|
$validate = $request->validate([
|
|
'id' => 'required',
|
|
'waktu_penilaian' => 'required',
|
|
'deskripsi_penilaian' => 'required'
|
|
]);
|
|
|
|
// $user = ['user' => 'rustammajid76@gmail.com'];
|
|
|
|
// $emailData = [
|
|
// 'email' => 'rustammajid76@gmail.com',
|
|
// 'subject' => 'Test',
|
|
// 'emailData' => '<h2>Hello, World!</h2><h2>This is the email content. Waktu Penilaian:</h2>'
|
|
// ];
|
|
|
|
// $this->sendMessage($emailData, $user);
|
|
|
|
$id = $request->input('id');
|
|
$penilaian = Penilaian::findOrFail($id);
|
|
|
|
$penilaian->update([
|
|
'waktu_penilaian' => $validate['waktu_penilaian'],
|
|
'deskripsi_penilaian' => $validate['deskripsi_penilaian'],
|
|
]);
|
|
|
|
return redirect()
|
|
->route('surveyor.index')
|
|
->with('success', 'Jadwal berhasil dibuat.');
|
|
} catch (\Exception $e) {
|
|
return response()->json(['buttonDisable' => $e->getMessage()]);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
public function storeAproved($id)
|
|
{
|
|
try {
|
|
|
|
|
|
$penilaian = Penilaian::findOrFail($id);
|
|
|
|
$penilaian->update([
|
|
'authorized_status' => 1,
|
|
]);
|
|
|
|
return redirect()
|
|
->route('permohonan.index')
|
|
->with('success', 'Jadwal berhasil di aprove.');
|
|
} catch (\Exception $e) {
|
|
return redirect()
|
|
->route('permohonan.index')
|
|
->with('error', 'Gagal membuat jadwal: ' . $e->getMessage());
|
|
}
|
|
}
|
|
|
|
|
|
public function storeFreeze() {
|
|
|
|
}
|
|
|
|
|
|
private function formatDataPembanding($request)
|
|
{
|
|
$dataPembanding = [];
|
|
$pembandingCount = count($request->input('alamat_pembanding', []));
|
|
|
|
for ($i = 0; $i < $pembandingCount; $i++) {
|
|
$pembanding = $this->formatSinglePembanding($request, $i);
|
|
|
|
// Perbaikan penanganan foto pembanding
|
|
$fotoKey = "foto_objek_pembanding_{$i}"; // Sesuaikan dengan nama field di form
|
|
if ($request->hasFile($fotoKey)) {
|
|
$pembanding['foto_objek'] = $this->handleFileUpload(
|
|
$request->file($fotoKey),
|
|
'pembanding',
|
|
"pembanding_{$i}"
|
|
);
|
|
}
|
|
|
|
$dataPembanding[] = $pembanding;
|
|
}
|
|
|
|
return $dataPembanding;
|
|
}
|
|
|
|
private function handleFileUpload($file, $folder, $prefix)
|
|
{
|
|
if (!$file) {
|
|
return null;
|
|
}
|
|
|
|
try {
|
|
// Buat nama file yang unik
|
|
$extension = $file->getClientOriginalExtension();
|
|
$fileName = $prefix . '_' . time() . '_' . uniqid() . '.' . $extension;
|
|
|
|
// Pastikan folder exists
|
|
$path = storage_path("app/public/{$folder}");
|
|
if (!File::exists($path)) {
|
|
File::makeDirectory($path, 0777, true);
|
|
}
|
|
|
|
// Simpan file
|
|
$file->storeAs("public/{$folder}", $fileName);
|
|
|
|
// Log untuk debugging
|
|
\Log::info("File berhasil disimpan: {$folder}/{$fileName}");
|
|
|
|
return $fileName;
|
|
} catch (\Exception $e) {
|
|
\Log::error("Error saat upload file: " . $e->getMessage());
|
|
throw $e;
|
|
}
|
|
}
|
|
|
|
private function formatSinglePembanding($request, $index)
|
|
{
|
|
$fields = [
|
|
'alamat', 'desa', 'kecamatan', 'kabupaten', 'provinsi',
|
|
'tahun', 'luas_tanah', 'luas_bangunan', 'tahun_bangunan',
|
|
'status_nara_sumber', 'harga', 'nama_nara_sumber',
|
|
'peruntukan', 'penawaran_transaksi', 'nomor_tlp',
|
|
'kordinat_lat', 'kordinat_lng', 'jenis_aset',
|
|
];
|
|
|
|
$pembanding = [];
|
|
foreach ($fields as $field) {
|
|
$inputName = "{$field}_pembanding";
|
|
$pembanding[$field] = $request->input($inputName)[$index] ?? null;
|
|
}
|
|
|
|
// Inisialisasi foto_objek sebagai null
|
|
$pembanding['foto_objek'] = null;
|
|
|
|
return $pembanding;
|
|
}
|
|
|
|
public function storeDataPembanding(Request $request)
|
|
{
|
|
try {
|
|
DB::beginTransaction();
|
|
|
|
$validator = $request->validate([
|
|
'permohonan_id' => 'required|exists:permohonan,id',
|
|
'type' => 'required|string',
|
|
'jenis_jaminan_id' => 'required',
|
|
'foto_objek' => 'nullable|image|max:2048',
|
|
'foto_objek_pembanding_*' => 'nullable|image|max:2048',
|
|
]);
|
|
|
|
if ($validator->fails()) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => 'Validasi gagal',
|
|
'errors' => $validator->errors()
|
|
], 422);
|
|
}
|
|
|
|
$objekPenilaian = $this->formatObjekPenilaian($request);
|
|
if ($request->hasFile('foto_objek')) {
|
|
$objekPenilaian['foto_objek'] = $this->handleFileUpload(
|
|
$request->file('foto_objek'),
|
|
'pembanding',
|
|
'objek_penilaian'
|
|
);
|
|
}
|
|
|
|
$formattedData = [
|
|
'permohonan_id' => $request->input('permohonan_id'),
|
|
'type' => $request->input('type'),
|
|
'jenis_jaminan_id' => $request->input('jenis_jaminan_id'),
|
|
'objek_penilaian' => $objekPenilaian,
|
|
'data_pembanding' => $this->formatDataPembanding($request)
|
|
];
|
|
|
|
$inspeksi = $this->saveInspeksi($formattedData);
|
|
|
|
DB::commit();
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => 'Data berhasil disimpan',
|
|
'data' => $formattedData
|
|
], 200);
|
|
|
|
} catch (\Exception $e) {
|
|
DB::rollBack();
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => 'Gagal menyimpan data: ' . $e->getMessage()
|
|
], 500);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
* Form inspeksi.
|
|
*/
|
|
|
|
public function formInspeksi($id, $jaminanId)
|
|
{
|
|
$permohonan = $this->getPermohonanJaminanId($id, $jaminanId);
|
|
|
|
// Auth::user()->id
|
|
|
|
|
|
$link_url_region = Teams::with('regions', 'teamsUsers')
|
|
->whereHas('teamsUsers', function ($query) {
|
|
$query->where('user_id', Auth::user()->id);
|
|
})->first();
|
|
|
|
$branches = Branch::all();
|
|
$provinces = Province::all();
|
|
|
|
$surveyor = $id;
|
|
$branches = Branch::all();
|
|
$provinces = Province::all();
|
|
$bentukTanah = BentukTanah::all();
|
|
$konturTanah = KonturTanah::all();
|
|
$posisiKavling = PosisiKavling::all();
|
|
$ketinggianTanah = KetinggianTanah::all();
|
|
$kondisiFisikTanah = KondisiFisikTanah::all();
|
|
$jenisBangunan = JenisBangunan::all();
|
|
$kondisiBangunan = KondisiBangunan::all();
|
|
$sifatBangunan = SifatBangunan::all();
|
|
$spekKategoriBagunan = SpekKategoritBangunan::all();
|
|
$spekBangunan = SpekBangunan::all();
|
|
$saranaPelengkap = SaranaPelengkap::all();
|
|
$arahMataAngin = ArahMataAngin::all();
|
|
$lantai = Lantai::all();
|
|
$viewUnit = ViewUnit::all();
|
|
$golMasySekitar = GolonganMasySekitar::all();
|
|
$tingkatKeramaian = TingkatKeramaian::all();
|
|
$laluLintasLokasi = LaluLintasLokasi::all();
|
|
$perkerasanJalan = PerkerasanJalan::all();
|
|
$jenisKendaraan = JenisKendaraan::all();
|
|
$jenisKapal = JenisKapal::all();
|
|
$jenisPesawat = JenisPesawat::all();
|
|
$modelAlatBerat = ModelAlatBerat::all();
|
|
$hubCadeb = HubunganPemilikJaminan::all();
|
|
$hubPenghuni = HubunganPenghuniJaminan::all();
|
|
$jenisJaminan = JenisJaminan::all();
|
|
$fasilitasObjek = FasilitasObjek::all();
|
|
$merupakanDaerah = MerupakanDaerah::all();
|
|
$terletakDiArea = TerletakArea::all();
|
|
$posisiUnit = PosisiUnit::all();
|
|
$bentukUnit = BentukUnit::all();
|
|
|
|
|
|
$inpeksi = Inspeksi::where('permohonan_id', $id)->where('jenis_jaminan_id', $jaminanId)->first();
|
|
$forminspeksi = null;
|
|
if ($inpeksi) {
|
|
$forminspeksi = json_decode($inpeksi->data_form, true);
|
|
}
|
|
return view('lpj::surveyor.components.inspeksi', compact(
|
|
'permohonan',
|
|
'surveyor',
|
|
'branches',
|
|
'provinces',
|
|
'bentukTanah',
|
|
'konturTanah',
|
|
'posisiKavling',
|
|
'kondisiFisikTanah',
|
|
'ketinggianTanah',
|
|
'kondisiBangunan',
|
|
'jenisBangunan',
|
|
'sifatBangunan',
|
|
'spekKategoriBagunan',
|
|
'spekBangunan',
|
|
'saranaPelengkap',
|
|
'arahMataAngin',
|
|
'lantai',
|
|
'viewUnit',
|
|
'golMasySekitar',
|
|
'tingkatKeramaian',
|
|
'laluLintasLokasi',
|
|
'perkerasanJalan',
|
|
'link_url_region',
|
|
'forminspeksi',
|
|
'jenisKendaraan',
|
|
'jenisKapal',
|
|
'jenisPesawat',
|
|
'modelAlatBerat',
|
|
'hubCadeb',
|
|
'jenisJaminan',
|
|
'fasilitasObjek',
|
|
'merupakanDaerah',
|
|
'terletakDiArea',
|
|
'posisiUnit',
|
|
'bentukUnit',
|
|
'hubPenghuni'
|
|
));
|
|
}
|
|
|
|
/**
|
|
* Denah.
|
|
*/
|
|
|
|
public function denah($id, $jaminanId)
|
|
{
|
|
$permohonan = $this->getPermohonanJaminanId($id, $jaminanId);
|
|
|
|
$denah = null;
|
|
|
|
$inpeksi = Inspeksi::where('permohonan_id', $id)->where('jenis_jaminan_id', $jaminanId)->first();
|
|
$formDenah = null;
|
|
if ($inpeksi) {
|
|
$formDenah = json_decode($inpeksi->denah_form, true);
|
|
}
|
|
|
|
// return response()->json($formDenah);
|
|
return view('lpj::surveyor.components.denah', compact('permohonan', 'denah', 'formDenah'));
|
|
}
|
|
|
|
/**
|
|
* Foto.
|
|
*/
|
|
|
|
public function foto($id, $jaminanId)
|
|
{
|
|
$permohonan = $this->getPermohonanJaminanId($id, $jaminanId);
|
|
$surveyor = $id;
|
|
$branches = Branch::all();
|
|
$provinces = Province::all();
|
|
|
|
|
|
|
|
$inpeksi = Inspeksi::where('permohonan_id', $id)->where('jenis_jaminan_id', $jaminanId)->first();
|
|
|
|
$formFoto = null;
|
|
if ($inpeksi) {
|
|
$formFoto = json_decode($inpeksi->foto_form, true);
|
|
}
|
|
$fotoJaminan = null;
|
|
|
|
// return response()->json([
|
|
// 'inspeksi' => $formFoto,
|
|
|
|
// ]);
|
|
|
|
return view('lpj::surveyor.components.foto', compact('permohonan', 'surveyor', 'branches', 'provinces', 'fotoJaminan', 'formFoto'));
|
|
}
|
|
|
|
/**
|
|
* Data pembanding.
|
|
*/
|
|
|
|
public function dataPembanding($id, $jaminanId)
|
|
{
|
|
try {
|
|
// Ambil data permohonan dengan eager loading
|
|
$permohonan = Permohonan::with([
|
|
'user',
|
|
'debiture.province',
|
|
'debiture.city',
|
|
'debiture.district',
|
|
'debiture.village',
|
|
'branch',
|
|
'tujuanPenilaian',
|
|
'penilaian'
|
|
])->findOrFail($id);
|
|
|
|
// Ambil data inspeksi
|
|
$inspeksi = Inspeksi::where([
|
|
'permohonan_id' => $id,
|
|
'jenis_jaminan_id' => $jaminanId
|
|
])->first();
|
|
|
|
// Inisialisasi variabel
|
|
$inspectionData = null;
|
|
$comparisons = null;
|
|
$fotoForm = null;
|
|
|
|
|
|
if ($inspeksi) {
|
|
|
|
$inspectionData = json_decode($inspeksi->data_form, true);
|
|
if (json_last_error() !== JSON_ERROR_NONE) {
|
|
throw new \Exception('Error decoding inspection data: ' . json_last_error_msg());
|
|
}
|
|
|
|
if ($inspeksi->data_pembanding) {
|
|
$comparisons = json_decode($inspeksi->data_pembanding, true);
|
|
if (json_last_error() !== JSON_ERROR_NONE) {
|
|
throw new \Exception('Error decoding comparison data: ' . json_last_error_msg());
|
|
}
|
|
|
|
|
|
}
|
|
$fotoForm = json_decode($inspeksi->foto_form, true);
|
|
|
|
}
|
|
|
|
// Ambil data pendukung
|
|
$data = $this->getCommonData();
|
|
$branches = Branch::all();
|
|
$provinces = Province::all();
|
|
|
|
return view('lpj::surveyor.components.data-pembanding', compact(
|
|
'permohonan',
|
|
'id',
|
|
'branches',
|
|
'provinces',
|
|
'inspectionData',
|
|
'comparisons',
|
|
'data',
|
|
'jaminanId',
|
|
'fotoForm'
|
|
));
|
|
|
|
} catch (\Exception $e) {
|
|
return redirect()
|
|
->back()
|
|
->with('error', 'Terjadi kesalahan saat memuat data: ' . $e->getMessage());
|
|
}
|
|
}
|
|
|
|
|
|
|
|
private function getHeader(string $type): array
|
|
{
|
|
return self::HEADERS[$type] ?? [];
|
|
}
|
|
|
|
public function data(Request $request)
|
|
{
|
|
|
|
$type = $request->route('type');
|
|
$header = $this->getHeader($request->route('type'));
|
|
return view('lpj::surveyor.data.index', compact('header'));
|
|
}
|
|
|
|
|
|
public function createData($type)
|
|
{
|
|
|
|
$spekKategoriBagunan = SpekKategoritBangunan::all();
|
|
$header = $this->getHeader($type);
|
|
return view('lpj::surveyor.data.form', compact('header', 'spekKategoriBagunan'));
|
|
}
|
|
|
|
|
|
public function storeData(SurveyorRequest $request, $type)
|
|
{
|
|
|
|
$validate = $request->validated();
|
|
if ($validate) {
|
|
|
|
try {
|
|
$type = $request->route('type');
|
|
|
|
$modelClass = $this->getModelClass($type);
|
|
|
|
if (!$modelClass) {
|
|
return redirect()
|
|
->route('basicdata.' . $type . '.index')
|
|
->with('error', 'Invalid type specified.');
|
|
}
|
|
|
|
if ($type == 'spek-bangunan') {
|
|
$validate['spek_kategori_bagunan_id'] = $request->spek_kategori_bagunan_id;
|
|
}
|
|
|
|
|
|
$data = array_merge($validate, ['status' => true]);
|
|
$modelClass::create($data);
|
|
|
|
return redirect()
|
|
->route('basicdata.' . $type . '.index')
|
|
->with('success', 'created successfully');
|
|
} catch (Exeception $e) {
|
|
return redirect()
|
|
->route('basicdata.' . $type . '.index')
|
|
->with('error', $th->getMessage());
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
public function editData($type, $id)
|
|
{
|
|
$dataMap = [
|
|
'bentuk-tanah' => ['Bentuk Tanah', 'bentuk-tanah', BentukTanah::class],
|
|
'kontur-tanah' => ['Kontur Tanah', 'kontur-tanah', KonturTanah::class],
|
|
'posisi-kavling' => ['Posisi Kavling', 'posisi-kavling', PosisiKavling::class],
|
|
'ketinggian-tanah' => ['Ketinggian Tanah', 'ketinggian-tanah', KetinggianTanah::class],
|
|
'kondisi-fisik-tanah' => ['Kondisi Fisik Tanah', 'kondisi-fisik-tanah', KondisiFisikTanah::class],
|
|
'jenis-bangunan' => ['Jenis Bangunan', 'jenis-bangunan', JenisBangunan::class],
|
|
'kondisi-bangunan' => ['Kondisi Bangunan', 'kondisi-bangunan', KondisiBangunan::class],
|
|
'sifat-bangunan' => ['Sifat Bangunan', 'sifat-bangunan', SifatBangunan::class],
|
|
'spek-bangunan' => ['Spek Bangunan', 'spek-bangunan', SpekBangunan::class],
|
|
'spek-kategori-bangunan' => ['Spek Kategori Bangunan', 'spek-kategori-bangunan', SpekKategoritBangunan::class],
|
|
'sarana-pelengkap' => ['Sarana Pelengkap', 'sarana-pelengkap', SaranaPelengkap::class],
|
|
'lantai-unit' => ['Lantai Unit', 'lantai-unit', Lantai::class],
|
|
'view-unit' => ['View Unit', 'view-unit', ViewUnit::class],
|
|
'gol-mas-sekitar' => ['Golongan Masyarakat Sekitar', 'gol-mas-sekitar', GolonganMasySekitar::class],
|
|
'jenis-pesawat' => ['Jenis Pasawat', 'jenis-pesawat', JenisPesawat::class],
|
|
'model-alat-berat' => ['Model Alat Berat', 'model-alat-berat', ModelAlatBerat::class],
|
|
'jenis-kapal' => ['Jenis Kapal', 'jenis-kapal', JenisKapal::class],
|
|
'jenis-kendaraan' => ['Jenis Kendaraan', 'jenis-kendaraan', JenisKendaraan::class],
|
|
'jenis-unit' => ['Jenis unit', 'jenis-unit', JenisUnit::class],
|
|
'terletak-area' => ['Terletak di Area', 'terletak-area', TerletakArea::class],
|
|
'merupakan-daerah' => ['Merupakan Daerah', 'merupakan-daerah', MerupakanDaerah::class],
|
|
'posisi-unit' => ['Posisi unit', 'posisi-unit', PosisiUnit::class],
|
|
'bentuk-unit' => ['Bentuk unit', 'bentuk-unit', BentukUnit::class],
|
|
'fasilitas-objek' => ['Fasilitas Umum Dekat Objek', 'fasilitas-objek', FasilitasObjek::class],
|
|
];
|
|
|
|
|
|
if (!array_key_exists($type, $dataMap)) {
|
|
return redirect()->back()->with('error', 'Invalid type specified.');
|
|
}
|
|
|
|
[$headers, $routeName, $modelClass] = $dataMap[$type];
|
|
|
|
$header = $dataMap[$type] ?? '';
|
|
$model = $modelClass::findOrFail($id);
|
|
|
|
$spekKategoriBagunan = null;
|
|
if ($type == 'spek-bangunan') {
|
|
$spekKategoriBagunan = SpekKategoritBangunan::all();
|
|
}
|
|
|
|
|
|
return view('lpj::surveyor.data.form', compact('header', 'model', 'spekKategoriBagunan'));
|
|
}
|
|
|
|
|
|
public function updateData(SurveyorRequest $request, $type, $id)
|
|
{
|
|
$validate = $request->validated();
|
|
if ($validate) {
|
|
$modelClass = $this->getModelClass($type);
|
|
|
|
if ($type == 'spek-bangunan') {
|
|
$validate['spek_kategori_bagunan_id'] = $request->spek_kategori_bagunan_id;
|
|
}
|
|
|
|
// Check if the provided type exists in the modelClasses
|
|
if (!$modelClass) {
|
|
return redirect()
|
|
->route('basicdata.' . $type . '.index')
|
|
->with('error', 'Invalid type specified.');
|
|
}
|
|
|
|
|
|
|
|
$model = $modelClass::findOrFail($id);
|
|
$model->update($validate);
|
|
|
|
// Redirect back with a success message
|
|
return redirect()
|
|
->route('basicdata.' . $type . '.index')
|
|
->with('success', 'Updated successfully');
|
|
}
|
|
}
|
|
|
|
|
|
public function update_analisa($id, Request $request)
|
|
{
|
|
try {
|
|
$permohonan = Permohonan::with([
|
|
'user',
|
|
'debiture.province',
|
|
'debiture.city',
|
|
'debiture.district',
|
|
'debiture.village',
|
|
'branch',
|
|
'tujuanPenilaian',
|
|
'penilaian',
|
|
'documents',
|
|
])->findOrFail($id);
|
|
|
|
$jenisAssetUpdated = false;
|
|
if ($request->input('types') == 'jenis_asset') {
|
|
$this->updateJenisAsset($permohonan, $request);
|
|
$jenisAssetUpdated = true;
|
|
}
|
|
|
|
if (in_array($request->input('types'), ['analisa_tanah', 'analisa_bangunan', 'analisa_unit'])) {
|
|
$key = match ($request->input('types')) {
|
|
'analisa_tanah' => 'luas_tanah',
|
|
'analisa_bangunan' => 'luas_bangunan',
|
|
'analisa_unit' => 'luas_unit',
|
|
};
|
|
|
|
$this->updateDetails($permohonan, $key, $request->input($key));
|
|
}
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => 'Data berhasil disimpan',
|
|
'jenis_asset' => $jenisAssetUpdated,
|
|
], 200);
|
|
} catch (\Exception $e) {
|
|
return response()->json(['error' => 'Something went wrong', 'message' => $e->getMessage()], 500);
|
|
}
|
|
}
|
|
|
|
|
|
private function updateJenisAsset($permohonan, $request)
|
|
{
|
|
$jenis_jaminan_id = $permohonan->debiture->documents->first()->jenis_jaminan_id;
|
|
DokumenJaminan::where('permohonan_id', $permohonan->id)
|
|
->where('jenis_jaminan_id', $jenis_jaminan_id)
|
|
->update([
|
|
'jenis_jaminan_id' => $request->input('jenis_asset'),
|
|
]);
|
|
}
|
|
|
|
private function updateDetails($permohonan, $key, $newValue)
|
|
{
|
|
$document = $permohonan->debiture->documents->first();
|
|
|
|
if (!$document) {
|
|
throw new \Exception("Document not found");
|
|
}
|
|
|
|
$detailsUpdate = DetailDokumenJaminan::where('dokumen_jaminan_id', $document->id)->first();
|
|
|
|
if (!$detailsUpdate) {
|
|
throw new \Exception("DetailDokumenJaminan not found");
|
|
}
|
|
|
|
$datas = json_decode($detailsUpdate->details, true) ?? [];
|
|
|
|
if (is_numeric($newValue)) {
|
|
$newValue = [$key => $newValue];
|
|
}
|
|
|
|
if (!is_array($newValue)) {
|
|
throw new \InvalidArgumentException("'{$key}' must be an array or valid JSON string");
|
|
}
|
|
|
|
foreach ($newValue as $subKey => $value) {
|
|
$datas[$subKey] = $value; // Update atau tambahkan key baru
|
|
}
|
|
|
|
$detailsUpdate->update([
|
|
'details' => json_encode($datas),
|
|
]);
|
|
}
|
|
|
|
|
|
public function dataForDatatables(Request $request)
|
|
{
|
|
if (is_null($this->user) || !$this->user->can('debitur.view')) {
|
|
// abort(403, 'Sorry! You are not allowed to view users.');
|
|
}
|
|
|
|
$query = Permohonan::query();
|
|
|
|
if ($request->has('search') && !empty($request->get('search'))) {
|
|
$search = $request->get('search');
|
|
$query->where(function ($q) use ($search) {
|
|
$q->where('nomor_registrasi', 'LIKE', '%' . $search . '%');
|
|
$q->orWhere('tanggal_permohonan', 'LIKE', '%' . $search . '%');
|
|
$q->orWhereRelation('user', 'name', 'LIKE', '%' . $search . '%');
|
|
$q->orWhereRelation('debiture', 'name', 'LIKE', '%' . $search . '%');
|
|
$q->orWhereRelation('tujuanPenilaian', 'name', 'LIKE', '%' . $search . '%');
|
|
$q->orWhereRelation('branch', 'name', 'LIKE', '%' . $search . '%');
|
|
$q->orWhere('status', 'LIKE', '%' . $search . '%');
|
|
});
|
|
}
|
|
|
|
$query->whereRaw('LOWER(status) = ?', ['assign']);
|
|
|
|
$query->whereHas('penilaian.userPenilai', function ($q) {
|
|
$q->where('user_id', Auth::user()->id);
|
|
$q->where('role', 'surveyor');
|
|
});
|
|
|
|
|
|
if ($request->has('sortOrder') && !empty($request->get('sortOrder'))) {
|
|
$order = $request->get('sortOrder');
|
|
$column = $request->get('sortField');
|
|
$query->orderBy($column, $order);
|
|
}
|
|
|
|
$totalRecords = $query->count();
|
|
|
|
$size = $request->get('size', 10);
|
|
if ($size == 0) {
|
|
$size = 10;
|
|
}
|
|
|
|
if ($request->has('page') && $request->has('size')) {
|
|
$page = $request->get('page', 1);
|
|
$offset = ($page - 1) * $size;
|
|
|
|
$query->skip($offset)->take($size);
|
|
}
|
|
|
|
$filteredRecords = $query->count();
|
|
$data = $query->with(['user', 'debiture', 'branch', 'tujuanPenilaian', 'jenisFasilitasKredit', 'penilaian'])->get();
|
|
|
|
$pageCount = ceil($totalRecords / $size);
|
|
|
|
$currentPage = max(1, $request->get('page', 1));
|
|
return response()->json([
|
|
'draw' => $request->get('draw'),
|
|
'recordsTotal' => $totalRecords,
|
|
'recordsFiltered' => $filteredRecords,
|
|
'pageCount' => $pageCount,
|
|
'page' => $currentPage,
|
|
'totalCount' => $totalRecords,
|
|
'data' => $data,
|
|
]);
|
|
}
|
|
|
|
|
|
|
|
public function dataForDatatablesData(Request $request, $type)
|
|
{
|
|
if (is_null($this->user) || !$this->user->can('jenis_aset.view')) {
|
|
//abort(403, 'Sorry! You are not allowed to view users.');
|
|
}
|
|
|
|
$models = [
|
|
'Bentuk Tanah' => BentukTanah::class,
|
|
'Kontur Tanah' => KonturTanah::class,
|
|
'Posisi Kavling' => PosisiKavling::class,
|
|
'Ketinggian Tanah' => KetinggianTanah::class,
|
|
'Kondisi Fisik Tanah' => KondisiFisikTanah::class,
|
|
'Jenis Bangunan' => JenisBangunan::class,
|
|
'Kondisi Bangunan' => KondisiBangunan::class,
|
|
'Sifat Bangunan' => SifatBangunan::class,
|
|
'Spek Kategori Bangunan' => SpekKategoritBangunan::class,
|
|
'Spek Bangunan' => SpekBangunan::class,
|
|
'Sarana Pelengkap' => SaranaPelengkap::class,
|
|
'Lalu Lintas Depan Lokasi' => LaluLintasLokasi::class,
|
|
'Tingkat Keramaian' => TingkatKeramaian::class,
|
|
'Golongan Masyarakat Sekitar' => GolonganMasySekitar::class,
|
|
'Lantai Unit' => Lantai::class,
|
|
'View Unit' => ViewUnit::class,
|
|
'Perkerasan jalan' => PerkerasanJalan::class,
|
|
'Jenis pesawat' => JenisPesawat::class,
|
|
'Model alat berat' => ModelAlatBerat::class,
|
|
'Jenis kapal' => JenisKapal::class,
|
|
'Jenis kendaraan' => JenisKendaraan::class,
|
|
'Terletak di Area' => TerletakArea::class,
|
|
'Posisi unit' => PosisiUnit::class,
|
|
'Bentuk unit' => BentukUnit::class,
|
|
'Fasilitas Umum Dekat Objek' => FasilitasObjek::class,
|
|
'Merupakan Daerah' => MerupakanDaerah::class,
|
|
'Jenis unit' => JenisUnit::class,
|
|
];
|
|
|
|
|
|
if (array_key_exists($type, $models)) {
|
|
$query = $models[$type]::query();
|
|
} else {
|
|
throw new InvalidArgumentException("Invalid type: $type");
|
|
}
|
|
|
|
if ($request->has('search') && !empty($request->get('search'))) {
|
|
$search = $request->get('search');
|
|
$query->where(function ($q) use ($search) {
|
|
$q->where('code', 'LIKE', "%$search%");
|
|
$q->orWhere('name', '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,
|
|
]);
|
|
}
|
|
|
|
public function destroy($id, $type)
|
|
{
|
|
try {
|
|
|
|
$modelClass = $this->getModelClass($type);
|
|
|
|
if (!$modelClass) {
|
|
return response()->json(['success' => false, 'message' => 'Invalid type specified.'], 400);
|
|
}
|
|
|
|
|
|
$model = $modelClass::findOrFail($id);
|
|
|
|
$model->delete();
|
|
return response()->json(['success' => true, 'message' => 'deleted successfully']);
|
|
} catch (ModelNotFoundException $e) {
|
|
return response()->json(['success' => false, 'message' => 'not found.'], 404);
|
|
} catch (Exception $e) {
|
|
return response()->json(['success' => false, 'message' => 'Failed to delete.'], 500);
|
|
}
|
|
}
|
|
|
|
|
|
private function getPermohonanJaminanId($id, $jaminanId)
|
|
{
|
|
return Permohonan::with([
|
|
'user',
|
|
'debiture.province',
|
|
'debiture.city',
|
|
'debiture.district',
|
|
'debiture.village',
|
|
'branch',
|
|
'tujuanPenilaian',
|
|
'penilaian',
|
|
'debiture.documents.jenisJaminan',
|
|
'debiture.documents' => function ($query) use ($jaminanId) {
|
|
$query->where('jenis_jaminan_id', $jaminanId);
|
|
}
|
|
])
|
|
->whereHas('debiture.documents', function ($query) use ($jaminanId) {
|
|
$query->where('jenis_jaminan_id', $jaminanId);
|
|
})
|
|
->findOrFail($id);
|
|
}
|
|
|
|
|
|
|
|
|
|
private function getModelClass(string $type): ?string
|
|
{
|
|
return $this->modelClasses[$type] ?? null;
|
|
}
|
|
|
|
|
|
|
|
private $modelClasses = [
|
|
'bentuk-tanah' => BentukTanah::class,
|
|
'kontur-tanah' => KonturTanah::class,
|
|
'posisi-kavling' => PosisiKavling::class,
|
|
'ketinggian-tanah' => KetinggianTanah::class,
|
|
'kondisi-fisik-tanah' => KondisiFisikTanah::class,
|
|
'jenis-bangunan' => JenisBangunan::class,
|
|
'kondisi-bangunan' => KondisiBangunan::class,
|
|
'sifat-bangunan' => SifatBangunan::class,
|
|
'sarana-pelengkap' => SaranaPelengkap::class,
|
|
'lalu-lintas-lokasi' => LaluLintasLokasi::class,
|
|
'tingkat-keramaian' => TingkatKeramaian::class,
|
|
'gol-mas-sekitar' => GolonganMasySekitar::class,
|
|
'spek-kategori-bangunan' => SpekKategoritBangunan::class,
|
|
'spek-bangunan' => SpekBangunan::class,
|
|
'lantai-unit' => Lantai::class,
|
|
'view-unit' => ViewUnit::class,
|
|
'jenis-pesawat' => JenisPesawat::class,
|
|
'model-alat-berat' => ModelAlatBerat::class,
|
|
'jenis-kapal' => JenisKapal::class,
|
|
'jenis-kendaraan' => JenisKendaraan::class,
|
|
'terletak-area' => TerletakArea::class,
|
|
'posisi-unit' => PosisiUnit::class,
|
|
'bentuk-unit' => BentukUnit::class,
|
|
'fasilitas-objek' => FasilitasObjek::class,
|
|
'merupakan-daerah' => MerupakanDaerah::class,
|
|
'jenis-unit' => JenisUnit::class,
|
|
'perkerasan-jalan' => PerkerasanJalan::class,
|
|
];
|
|
|
|
|
|
|
|
|
|
private function getCommonData()
|
|
{
|
|
return [
|
|
'branches' => Branch::all(),
|
|
'provinces' => Province::all(),
|
|
'bentukTanah' => BentukTanah::all(),
|
|
'konturTanah' => KonturTanah::all(),
|
|
'posisiKavling' => PosisiKavling::all(),
|
|
'ketinggianTanah' => KetinggianTanah::all(),
|
|
'kondisiFisikTanah' => KondisiFisikTanah::all(),
|
|
'jenisBangunan' => JenisBangunan::all(),
|
|
'kondisiBangunan' => KondisiBangunan::all(),
|
|
'sifatBangunan' => SifatBangunan::all(),
|
|
'spekKategoriBangunan' => SpekKategoritBangunan::all(),
|
|
'spekBangunan' => SpekBangunan::all(),
|
|
'saranaPelengkap' => SaranaPelengkap::all(),
|
|
'arahMataAngin' => ArahMataAngin::all(),
|
|
'lantai' => Lantai::all(),
|
|
'viewUnit' => ViewUnit::all(),
|
|
'golMasySekitar' => GolonganMasySekitar::all(),
|
|
'tingkatKeramaian' => TingkatKeramaian::all(),
|
|
'laluLintasLokasi' => LaluLintasLokasi::all(),
|
|
'jenisPesawat' => JenisPesawat::all(),
|
|
'modelAlatBerat' => ModelAlatBerat::all(),
|
|
'jenisKapal' => JenisKapal::all(),
|
|
'jenisKendaraan' => JenisKendaraan::all(),
|
|
'terletakArea' => TerletakArea::all(),
|
|
'posisiUnit' => PosisiUnit::all(),
|
|
'bentukUnit' => BentukUnit::all(),
|
|
'fasilitasObjek' => FasilitasObjek::all(),
|
|
'merupakanDaerah' => MerupakanDaerah::all(),
|
|
'jenisUnit' => JenisUnit::all(),
|
|
'jenisJaminan' => JenisJaminan::all(),
|
|
];
|
|
}
|
|
|
|
|
|
private const HEADERS = [
|
|
'bentuk-tanah' => ['Bentuk Tanah', 'bentuk-tanah'],
|
|
'kontur-tanah' => ['Kontur Tanah', 'kontur-tanah'],
|
|
'posisi-kavling' => ['Posisi Kavling', 'posisi-kavling'],
|
|
'ketinggian-tanah' => ['Ketinggian Tanah', 'ketinggian-tanah'],
|
|
'kondisi-fisik-tanah' => ['Kondisi Fisik Tanah', 'kondisi-fisik-tanah'],
|
|
'jenis-bangunan' => ['Jenis Bangunan', 'jenis-bangunan'],
|
|
'kondisi-bangunan' => ['Kondisi Bangunan', 'kondisi-bangunan'],
|
|
'sifat-bangunan' => ['Sifat Bangunan', 'sifat-bangunan'],
|
|
'sarana-pelengkap' => ['Sarana Pelengkap', 'sarana-pelengkap'],
|
|
'lalu-lintas-lokasi' => ['Lalu Lintas Depan Lokasi', 'lalu-lintas-lokasi'],
|
|
'tingkat-keramaian' => ['Tingkat Keramaian', 'tingkat-keramaian'],
|
|
'gol-mas-sekitar' => ['Golongan Masyarakat Sekitar', 'gol-mas-sekitar'],
|
|
'spek-kategori-bangunan' => ['Spek Kategori Bangunan', 'spek-kategori-bangunan'],
|
|
'spek-bangunan' => ['Spek Bangunan', 'spek-bangunan'],
|
|
'lantai-unit' => ['Lantai Unit', 'lantai-unit'],
|
|
'view-unit' => ['View Unit', 'view-unit'],
|
|
'perkerasan-jalan' => ['Perkerasan jalan', 'perkerasan-jalan'],
|
|
'jenis-pesawat' => ['Jenis pesawat', 'jenis-pesawat'],
|
|
'model-alat-berat' => ['Model alat berat', 'model-alat-berat'],
|
|
'jenis-kapal' => ['Jenis kapal', 'jenis-kapal'],
|
|
'jenis-kendaraan' => ['Jenis kendaraan', 'jenis-kendaraan'],
|
|
'jenis-unit' => ['Jenis unit', 'jenis-unit'],
|
|
'terletak-area' => ['Terletak di Area', 'terletak-area'],
|
|
'merupakan-daerah' => ['Merupakan Daerah', 'merupakan-daerah'],
|
|
'posisi-unit' => ['Posisi unit', 'posisi-unit'],
|
|
'bentuk-unit' => ['Bentuk unit', 'bentuk-unit'],
|
|
'fasilitas-objek' => ['Fasilitas Umum Dekat Objek', 'fasilitas-objek'],
|
|
];
|
|
|
|
private function getAssetData(array $data): array
|
|
{
|
|
$alamatData = [
|
|
'nama_jalan' => $data['nama_jalan'] ?? null,
|
|
'desa_kelurahan' => $data['desa_kelurahan'] ?? null,
|
|
'kecamatan' => $data['kecamatan'] ?? null,
|
|
'kota_kabupaten' => $data['kota_kabupaten'] ?? null,
|
|
'provinsi' => $data['provinsi'] ?? null,
|
|
];
|
|
|
|
return [
|
|
'asset' => [
|
|
'debitur_perwakilan' => $data['debitur_perwakilan'] ?? [],
|
|
'jenis_asset' => [
|
|
$data['jenis_asset'] => ($data['jenis_asset'] === 'sesuai')
|
|
? $data['jenis_asset_name']
|
|
: ($data['jenis_asset_tidak_sesuai'] ?? null)
|
|
],
|
|
'alamat' => [
|
|
$data['alamat_sesuai'] => $alamatData
|
|
],
|
|
'hub_cadeb' => [
|
|
$data['hub_cadeb'] => $this->getFieldData(
|
|
$data,
|
|
'hub_cadeb',
|
|
true
|
|
)
|
|
],
|
|
'hub_cadeb_penghuni' => [
|
|
$data['hub_cadeb_penghuni'] => $this->getFieldData(
|
|
$data,
|
|
'hub_cadeb_penghuni',
|
|
true
|
|
)
|
|
],
|
|
|
|
'kordinat_lng' => $data['kordinat_lng'] ?? null,
|
|
'kordinat_lat' => $data['kordinat_lat'] ?? null,
|
|
]
|
|
];
|
|
}
|
|
|
|
|
|
private function getTanahData(array $data): array
|
|
{
|
|
return [
|
|
'tanah' => [
|
|
'luas_tanah' => $this->getFieldData(
|
|
$data,
|
|
'luas_tanah',
|
|
true
|
|
),
|
|
'hadap_mata_angin' => $this->getFieldData(
|
|
$data,
|
|
'hadap_mata_angin',
|
|
true
|
|
),
|
|
'bentuk_tanah' => $this->getFieldData(
|
|
$data,
|
|
'bentuk_tanah',
|
|
false,
|
|
'lainnya'
|
|
),
|
|
'kontur_tanah' => $data['kontur_tanah'] ?? [],
|
|
'ketinggian_tanah' => [
|
|
'ketinggian' => $data['kontur_tanah'] ?? null,
|
|
'lebih_tinggi' => $data['ketinggian_lebih_tinggi'] ?? null,
|
|
'lebih_rendah' => $data['ketinggian_lebih_rendah'] ?? null
|
|
],
|
|
'kontur_jalan' => $data['kontur_jalan'] ?? null,
|
|
'ketinggian_jalan' => $data['ketinggian_jalan'] ?? [],
|
|
'posisi_kavling' => $this->getFieldData(
|
|
$data,
|
|
'posisi_kavling',
|
|
false,
|
|
'lainnya'
|
|
),
|
|
'tusuk_sate' => $data['tusuk_sate'] ?? null,
|
|
'lockland' => $data['lockland'] ?? null,
|
|
'kondisi_fisik_tanah' => $this->getFieldData(
|
|
$data,
|
|
'kondisi_fisik_tanah',
|
|
false,
|
|
'lainnya'
|
|
)
|
|
]
|
|
];
|
|
}
|
|
|
|
|
|
private function getBangunanData($data, $request): array
|
|
{
|
|
$data = $request->all();
|
|
$result = [];
|
|
|
|
// foreach ($data['nama_bangunan'] as $index => $bangunan) {
|
|
// $bangunanData = [
|
|
// 'bangunan' => $bangunan,
|
|
// 'kategori' => []
|
|
// ];
|
|
|
|
// foreach ($data['spek_kategori_bangunan'] as $kategoriIndex => $kategori) {
|
|
// if (isset($data['spek_bangunan'][$kategori])) {
|
|
// $bangunanData['kategori'][] = [
|
|
// 'kategori' => $kategori,
|
|
// 'spesifikasi' => $data['spek_bangunan'][$kategori]
|
|
// ];
|
|
// }
|
|
// }
|
|
|
|
// $result[] = $bangunanData;
|
|
// }
|
|
|
|
return [
|
|
'bangunan' => [
|
|
'luas_tanah_bagunan' => $this->getFieldData(
|
|
$data,
|
|
'luas_tanah_bagunan',
|
|
true
|
|
),
|
|
'jenis_bangunan' => $data['jenis_bangunan'] ?? null,
|
|
'kondisi_bangunan' => $data['kondisi_bangunan'] ?? null,
|
|
'sifat_bangunan' => $data['sifat_bangunan'] ?? null,
|
|
'sifat_bangunan_input' => $data['sifat_bangunan_input'] ?? null,
|
|
'spesifikasi_bangunan' => $result ?? null,
|
|
'sarana_pelengkap' => $this->mapArrayWithInputs(
|
|
$data['sarana_pelengkap'] ?? [],
|
|
$data['sarana_pelengkap_input'] ?? []
|
|
),
|
|
],
|
|
];
|
|
}
|
|
|
|
private function getLingkunganData($data, $request): array
|
|
{
|
|
return [
|
|
'lingkungan' => [
|
|
'jarak_jalan_utama' => $data['jarak_jalan_utama'] ?? null,
|
|
'jalan_linkungan' => $data['jalan_linkungan'] ?? null,
|
|
'jarak_cbd_point' => $data['jarak_cbd_point'] ?? null,
|
|
'nama_cbd_point' => $data['nama_cbd_point'] ?? null,
|
|
'lebar_perkerasan_jalan' => $data['lebar_perkerasan_jalan'] ?? null,
|
|
'perkerasan_jalan' => $data['perkerasan_jalan'] ?? null,
|
|
'lalu_lintas' => $data['lalu_lintas'] ?? null,
|
|
'gol_mas_sekitar' => $data['gol_mas_sekitar'] ?? null,
|
|
'tingkat_keramaian' => $data['tingkat_keramaian'] ?? null,
|
|
'terletak_diarea' => $data['terletak_diarea'] ?? null,
|
|
'disekitar_lokasi' => $data['disekitar_lokasi'] === 'yes' ? [
|
|
'kondisi' => $data['kondisi_bagunan_disekitar_lokasi'] ?? null,
|
|
'sifat' => $data['sifat_bagunan_disekitar_lokasi'] ?? null,
|
|
] : $data['disekitar_lokasi'],
|
|
'kondisi_bangunan_sekitar' => $data['kondisi_bangunan_sekitar'] ?? null,
|
|
'sifat_bangunan_sekitar' => $data['sifat_bangunan_sekitar'] ?? null,
|
|
'dekat_makam' => $data['dekat_makam'] ?? null,
|
|
'jarak_makam' => $data['jarak_makam'] ?? null,
|
|
'nama_makam' => $data['nama_makam'] ?? null,
|
|
'dekat_tps' => $data['dekat_tps'] ?? null,
|
|
'jarak_tps' => $data['jarak_tps'] ?? null,
|
|
'nama_tps' => $data['nama_tps'] ?? null,
|
|
'merupakan_daerah' => $data['merupakan_daerah'] ?? null,
|
|
'fasilitas_dekat_object' => $data['fasilitas_dekat_object'] ?? null,
|
|
]
|
|
];
|
|
}
|
|
|
|
private function getFactData($data, $request): array
|
|
{
|
|
$factData = [
|
|
'fakta' => [
|
|
'fakta_positif' => $data['fakta_positif'] ?? null,
|
|
'fakta_negatif' => $data['fakta_negatif'] ?? null,
|
|
'rute_menuju' => $data['rute_menuju'] ?? null,
|
|
'batas_batas' => $this->mapArrayWithInputs(
|
|
$data['batas_batas'] ?? null,
|
|
$data['batas_batas_input'] ?? null
|
|
),
|
|
'kondisi_lingkungan' => $data['kondisi_lingkungan'] ?? null,
|
|
'kondisi_lain_bangunan' => $data['kondisi_lain_bangunan'] ?? null,
|
|
'informasi_dokument' => $data['informasi_dokument'] ?? null,
|
|
'peruntukan' => $data['peruntukan'] ?? null,
|
|
'kdb' => $data['kdb'] ?? null,
|
|
'kdh' => $data['kdh'] ?? null,
|
|
'gsb' => $data['gsb'] ?? null,
|
|
'max_lantai' => $data['max_lantai'] ?? null,
|
|
'klb' => $data['klb'] ?? null,
|
|
'gss' => $data['gss'] ?? null,
|
|
'pelebaran_jalan' => $data['pelebaran_jalan'] ?? null,
|
|
'nama_petugas' => $data['nama_petugas'] ?? null,
|
|
'keterangan' => $data['keterangan'] ?? null,
|
|
]
|
|
];
|
|
|
|
|
|
$inspeksi = Inspeksi::where('permohonan_id', $request->input('permohonan_id'))->where('jenis_jaminan_id', $request->input('jenis_jaminan_id'))->first();
|
|
|
|
|
|
$fotoTypes = [
|
|
'foto_gistaru',
|
|
'foto_bhumi',
|
|
'foto_argis_region',
|
|
'foto_tempat'
|
|
];
|
|
|
|
if ($inspeksi) {
|
|
$dataForm = json_decode($inspeksi->data_form, true);
|
|
foreach ($fotoTypes as $fotoType) {
|
|
// Jika ada file baru diupload
|
|
if ($request->hasFile($fotoType)) {
|
|
$factData[$fotoType] = $this->updateOrDeleteFile($dataForm, $request, $fotoType);
|
|
} else {
|
|
$factData[$fotoType] = $dataForm[$fotoType] ?? null;
|
|
}
|
|
}
|
|
} else {
|
|
foreach ($fotoTypes as $fotoType) {
|
|
$factData[$fotoType] = $this->updateOrDeleteFile($data, $request, $fotoType);
|
|
}
|
|
}
|
|
return $factData;
|
|
}
|
|
|
|
private function updateOrDeleteFile($data, $request, $fileKey)
|
|
{
|
|
if ($request->hasFile($fileKey)) {
|
|
$file = $request->file($fileKey);
|
|
if ($file->isValid()) {
|
|
$fileName = time() . '_' . $file->getClientOriginalName();
|
|
$path = $file->storeAs("public/surveyor/{$request->type}", $fileName);
|
|
|
|
if ($path === false) {
|
|
throw new Exception("Failed to store file for {$fileKey}");
|
|
}
|
|
if (isset($data[$fileKey]) && $data[$fileKey]) {
|
|
$this->deleteFile($data[$fileKey]);
|
|
}
|
|
return str_replace('public/', '', $path);
|
|
} else {
|
|
throw new Exception("Invalid file upload for {$fileKey}");
|
|
}
|
|
} elseif (isset($data[$fileKey]) && $data[$fileKey]) {
|
|
return $data[$fileKey];
|
|
} else {
|
|
return null;
|
|
}
|
|
}
|
|
|
|
private function deleteFile($filePath)
|
|
{
|
|
$fullPath = storage_path('app/public/' . $filePath);
|
|
if (file_exists($fullPath)) {
|
|
unlink($fullPath);
|
|
}
|
|
}
|
|
|
|
|
|
private function getKapalData($data, $request): array
|
|
{
|
|
return [
|
|
|
|
'action' => $data['action'] ?? null,
|
|
'nama_wakil_debitur' => $data['nama_wakil_debitur'] ?? null,
|
|
'hub_calon_debitur' => $data['hub_calon_debitur'] ?? null,
|
|
'dermaga' => $data['dermaga'] ?? null,
|
|
'desa_kelurahan' => $data['desa_kelurahan'] ?? null,
|
|
'kecamatan' => $data['kecamatan'] ?? null,
|
|
'kota_madya' => $data['kota_madya'] ?? null,
|
|
'provinsi' => $data['provinsi'] ?? null,
|
|
'jenis' => $data['jenis'] ?? null,
|
|
'size' => $data['size'] ?? null,
|
|
'kondisi' => $data['kondisi'] ?? null,
|
|
'klasifikasi' => $data['klasifikasi'] ?? null,
|
|
|
|
'nama_kapal' => $data['nama_kapal'] ?? null,
|
|
'pemilik_kapal' => $data['pemilik_kapal'] ?? null,
|
|
'bendera' => $data['bendera'] ?? null,
|
|
'nomor_selar' => $data['nomor_selar'] ?? null,
|
|
'kapal' => $data['kapal'] ?? null,
|
|
'galangan_kapal' => $data['galangan_kapal'] ?? null,
|
|
'kapal_shipyard' => $data['kapal_shipyard'] ?? null,
|
|
'tahun_pembuatan' => $data['tahun_pembuatan'] ?? null,
|
|
'tahun_launcing' => $data['tahun_launcing'] ?? null,
|
|
'dwt' => $data['dwt'] ?? null,
|
|
'lwt' => $data['lwt'] ?? null,
|
|
'gross_tonnage' => $data['gross_tonnage'] ?? null,
|
|
'net_tonnage' => $data['net_tonnage'] ?? null,
|
|
'tenaga_mesin' => $data['tenaga_mesin'] ?? null,
|
|
'loa' => $data['loa'] ?? null,
|
|
'lbp' => $data['lbp'] ?? null,
|
|
'beam' => $data['beam'] ?? null,
|
|
'depth' => $data['depth'] ?? null,
|
|
'draft' => $data['draft'] ?? null,
|
|
|
|
|
|
'lambung_kapal' => $data['lambung_kapal'] ?? null,
|
|
'dek' => $data['dek'] ?? null,
|
|
'struktur_rangka' => $data['struktur_rangka'] ?? null,
|
|
'palka' => $data['palka'] ?? null,
|
|
'pondasi_mesin' => $data['pondasi_mesin'] ?? null,
|
|
'area_mesin' => $data['area_mesin'] ?? null,
|
|
'cat_dan_korosi' => $data['cat_dan_korosi'] ?? null,
|
|
'sistem_pengelasan' => $data['sistem_pengelasan'] ?? null,
|
|
'deskripsi_struktur' => $data['deskripsi_struktur'] ?? null,
|
|
|
|
'sekoci' => $data['sekoci'] ?? null,
|
|
'jaket_pelampung' => $data['jaket_pelampung'] ?? null,
|
|
'alat_pemadaman' => $data['alat_pemadaman'] ?? null,
|
|
'rambu_darurat' => $data['rambu_darurat'] ?? null,
|
|
'sistem_alarm' => $data['sistem_alarm'] ?? null,
|
|
'sistem_pencegah' => $data['sistem_pencegah'] ?? null,
|
|
'kebakaran' => $data['kebakaran'] ?? null,
|
|
'lampu_darurat' => $data['lampu_darurat'] ?? null,
|
|
'deskripsi_peralatan' => $data['deskripsi_peralatan'] ?? null,
|
|
|
|
'gps' => $data['gps'] ?? null,
|
|
'radar' => $data['radar'] ?? null,
|
|
'radio_komunikasi' => $data['radio_komunikasi'] ?? null,
|
|
'lampu_navigasi' => $data['lampu_navigasi'] ?? null,
|
|
'sistem_kendali_otomatis' => $data['sistem_kendali_otomatis'] ?? null,
|
|
'kompas' => $data['kompas'] ?? null,
|
|
'deskripsi_navigasi' => $data['deskripsi_navigasi'] ?? null,
|
|
|
|
'mesin_utama' => $data['mesin_utama'] ?? null,
|
|
'mesin_bantu' => $data['mesin_bantu'] ?? null,
|
|
'pompa_pendingin' => $data['pompa_pendingin'] ?? null,
|
|
'sistem_pelumasan' => $data['sistem_pelumasan'] ?? null,
|
|
'propeller' => $data['propeller'] ?? null,
|
|
'sistem_kelistrikan' => $data['sistem_kelistrikan'] ?? null,
|
|
'deskripsi_mesin_penggerak' => $data['deskripsi_mesin_penggerak'] ?? null,
|
|
|
|
'lampu_navigasi' => $data['lampu_navigasi'] ?? null,
|
|
'sistem_penerangan' => $data['sistem_penerangan'] ?? null,
|
|
'sistem_panel_distribusi' => $data['sistem_panel_distribusi'] ?? null,
|
|
'kabel_perangkat' => $data['kabel_perangkat'] ?? null,
|
|
'deskripsi_kelistrikan' => $data['deskripsi_kelistrikan'] ?? null,
|
|
|
|
'kebersihan_dek_luar' => $data['kebersihan_dek_luar'] ?? null,
|
|
'tangki_limbah' => $data['tangki_limbah'] ?? null,
|
|
'sistem_pengelolaan_limbah' => $data['sistem_pengelolaan_limbah'] ?? null,
|
|
'pengelolaan_air_ballast' => $data['pengelolaan_air_ballast'] ?? null,
|
|
'deskripsi_kebersihan' => $data['deskripsi_kebersihan'] ?? null,
|
|
|
|
'fakta_positif' => $data['fakta_positif'] ?? null,
|
|
'fakta_negatif' => $data['fakta_negatif'] ?? null,
|
|
'analisa_makro' => $data['analisa_makro'] ?? null,
|
|
'kesimpulan' => $data['kesimpulan'] ?? null,
|
|
'catatan' => $data['catatan'] ?? null,
|
|
|
|
];
|
|
}
|
|
public function getKendaraanData($data, $request): array
|
|
{
|
|
return [
|
|
'action' => $data['action'] ?? null,
|
|
'tanggal_survey' => $data['tanggal_survey'] ?? null,
|
|
'nama_wakil' => $data['nama_wakil'] ?? null,
|
|
'hub_calon_debitur' => $data['hub_calon_debitur'] ?? null,
|
|
'nama_jalan' => $data['nama_jalan'] ?? null,
|
|
'perumahan_gang' => $data['perumahan_gang'] ?? null,
|
|
'blok_nomor' => $data['blok_nomor'] ?? null,
|
|
'desa_kelurahan' => $data['desa_kelurahan'] ?? null,
|
|
'kecamatan' => $data['kecamatan'] ?? null,
|
|
'kota_madya' => $data['kota_madya'] ?? null,
|
|
'provinsi' => $data['provinsi'] ?? null,
|
|
'kondisi' => $data['kondisi'] ?? null,
|
|
'nomor_polisi' => $data['nomor_polisi'] ?? null,
|
|
'nomor_polis_tidak_sesuai' => $data['nomor_polis_tidak_sesuai'] ?? null,
|
|
'merek' => $data['merek'] ?? null,
|
|
'merek_tidak_sesuai' => $data['merek_tidak_sesuai'] ?? null,
|
|
'warna' => $data['warna'] ?? null,
|
|
'warna_tidak_sesuai' => $data['warna_tidak_sesuai'] ?? null,
|
|
'nomor_rangka' => $data['nomor_rangka'] ?? null,
|
|
'nomor_rangka_tidak_sesuai' => $data['nomor_rangka_tidak_sesuai'] ?? null,
|
|
'nomor_mesin' => $data['nomor_mesin'] ?? null,
|
|
'nomor_mesin_tidak_sesuai' => $data['nomor_mesin_tidak_sesuai'] ?? null,
|
|
'posisi_kilometer' => $data['posisi_kilometer'] ?? null,
|
|
'transmisi' => $data['transmisi'] ?? null,
|
|
|
|
|
|
'mesin_panel_instrument' => $data['mesin_panel_instrument'] ?? null,
|
|
'fungsi_mesin_panel_instrument' => $data['fungsi_mesin_panel_instrument'] ?? null,
|
|
'interior' => $data['interior'] ?? null,
|
|
'interior' => $data['interior'] ?? null,
|
|
|
|
'jumlah_pintu' => $data['jumlah_pintu'] ?? null,
|
|
'rangka_karoseri' => $data['rangka_karoseri'] ?? null,
|
|
'ban' => $data['ban'] ?? null,
|
|
'velg' => $data['velg'] ?? null,
|
|
'bamper_depan' => $data['bamper_depan'] ?? null,
|
|
'bamper_belakang' => $data['bamper_belakang'] ?? null,
|
|
'lampu_depan' => $data['lampu_depan'] ?? null,
|
|
'lampu_belakang' => $data['lampu_belakang'] ?? null,
|
|
'kaca_kendaraan' => $data['kaca_kendaraan'] ?? null,
|
|
'air_conditioner' => $data['air_conditioner'] ?? null,
|
|
'tape_radio_cd' => $data['tape_radio_cd'] ?? null,
|
|
'sensor_parkir' => $data['sensor_parkir'] ?? null,
|
|
'sensor_camera_recorder' => $data['sensor_camera_recorder'] ?? null,
|
|
'lcd' => $data['lcd'] ?? null,
|
|
'sabuk_keselamatan' => $data['sabuk_keselamatan'] ?? null,
|
|
'airbag' => $data['airbag'] ?? null,
|
|
'asuransi' => $data['asuransi'] ?? null,
|
|
'perusahaan_asuransi' => $data['perusahaan_asuransi'] ?? null,
|
|
'tahun_berakhir' => $data['tahun_berakhir'] ?? null,
|
|
|
|
|
|
'fakta_positif' => $data['fakta_positif'] ?? null,
|
|
'fakta_negatif' => $data['fakta_negatif'] ?? null,
|
|
'analisa_makro' => $data['analisa_makro'] ?? null,
|
|
'kesimpulan' => $data['kesimpulan'] ?? null,
|
|
'catatan' => $data['catatan'] ?? null,
|
|
];
|
|
}
|
|
|
|
public function getMesinData($data, $request): array
|
|
{
|
|
return [
|
|
'action' => $data['action'] ?? null,
|
|
'nama_wakil' => $data['nama_wakil'] ?? null,
|
|
'nama_jalan' => $data['nama_jalan'] ?? null,
|
|
'perumahan_gang' => $data['perumahan_gang'] ?? null,
|
|
'blok' => $data['blok'] ?? null,
|
|
'desa_kelurahan' => $data['desa_kelurahan'] ?? null,
|
|
'kecamatan' => $data['kecamatan'] ?? null,
|
|
'kota_madya' => $data['kota_madya'] ?? null,
|
|
'provinsi' => $data['provinsi'] ?? null,
|
|
'hub_calon_debitur' => $data['hub_calon_debitur'] ?? null,
|
|
'tipe_model' => $data['tipe_model'] ?? null,
|
|
'merek' => $data['merek'] ?? null,
|
|
'tahun_pembuatan' => $data['tahun_pembuatan'] ?? null,
|
|
'negara_pembuat' => $data['negara_pembuat'] ?? null,
|
|
'kondisi_mesin' => $data['kondisi_mesin'] ?? null,
|
|
'faktor_positif' => $data['faktor_positif'] ?? null,
|
|
'faktor_negatif' => $data['faktor_negatif'] ?? null,
|
|
'kesimpulan' => $data['kesimpulan'] ?? null,
|
|
'catatan' => $data['catatan'] ?? null,
|
|
];
|
|
}
|
|
|
|
public function getAlatBeratData($data, $request): array
|
|
{
|
|
return [
|
|
'action' => $data['action'] ?? null,
|
|
'tanggal_survey' => $data['tanggal_survey'] ?? null,
|
|
'nama_wakil' => $data['nama_wakil'] ?? null,
|
|
'hub_calon_debitur' => $data['hub_calon_debitur'] ?? null,
|
|
'dengan_wadeb' => $data['dengan_wadeb'] ?? null,
|
|
'nama_jalan' => $data['nama_jalan'] ?? null,
|
|
'perumahan_gang' => $data['perumahan_gang'] ?? null,
|
|
'blok' => $data['blok'] ?? null,
|
|
'desa_kelurahan' => $data['desa_kelurahan'] ?? null,
|
|
'kecamatan' => $data['kecamatan'] ?? null,
|
|
'kota_madya' => $data['kota_madya'] ?? null,
|
|
'provinsi' => $data['provinsi'] ?? null,
|
|
'jenis_model' => $data['jenis_model'] ?? null,
|
|
'nomor_lambung' => $data['nomor_lambung'] ?? null,
|
|
'model_unit' => $data['model_unit'] ?? null,
|
|
'tahun_pembuatan' => $data['tahun_pembuatan'] ?? null,
|
|
'merk' => $data['merk'] ?? null,
|
|
'negara_pembuat' => $data['negara_pembuat'] ?? null,
|
|
'tahun_pembelian' => $data['tahun_pembelian'] ?? null,
|
|
'nomor_faktur' => $data['nomor_faktur'] ?? null,
|
|
'nomor_kontrak' => $data['nomor_kontrak'] ?? null,
|
|
'nama_pemilik' => $data['nama_pemilik'] ?? null,
|
|
'alamat_pemilik' => $data['alamat_pemilik'] ?? null,
|
|
'nomor_asuransi' => $data['nomor_asuransi'] ?? null,
|
|
'nomor_rangka' => $data['nomor_rangka'] ?? null,
|
|
'nomor_mesin' => $data['nomor_mesin'] ?? null,
|
|
'hour_mesters' => $data['hour_mesters'] ?? null,
|
|
'overhaul_mesin' => $data['overhaul_mesin'] ?? null,
|
|
|
|
'mesin_panel' => $data['mesin_panel'] ?? null,
|
|
'fungsi_panel' => $data['fungsi_panel'] ?? null,
|
|
'interior' => $data['interior'] ?? null,
|
|
'rangka_Karoseri' => $data['rangka_Karoseri'] ?? null,
|
|
'ban' => $data['ban'] ?? null,
|
|
'velg' => $data['velg'] ?? null,
|
|
'air_conditioner' => $data['air_conditioner'] ?? null,
|
|
'aksesoris' => $data['aksesoris'] ?? null,
|
|
'lcd' => $data['lcd'] ?? null,
|
|
'perlengkapan' => $data['perlengkapan'] ?? null,
|
|
'asuransi' => $data['asuransi'] ?? null,
|
|
'perusahaan_asuransi' => $data['perusahaan_asuransi'] ?? null,
|
|
'tahun_berakhir' => $data['tahun_berakhir'] ?? null,
|
|
'sensor_kamera' => $data['sensor_kamera'] ?? null,
|
|
'sabuk_keselamatan' => $data['sabuk_keselamatan'] ?? null,
|
|
'air_bag' => $data['air_bag'] ?? null,
|
|
|
|
'faktor_positif' => $data['faktor_positif'] ?? null,
|
|
'faktor_negatif' => $data['faktor_negatif'] ?? null,
|
|
'kesimpulan' => $data['kesimpulan'] ?? null,
|
|
'catatan' => $data['catatan'] ?? null,
|
|
];
|
|
}
|
|
|
|
private function getPesawatData($data, $request): array
|
|
{
|
|
return [
|
|
'action' => $data['action'] ?? null,
|
|
'tanggal_survey' => $data['tanggal_survey'] ?? null,
|
|
'nama_wakil' => $data['nama_wakil'] ?? null,
|
|
'hub_calon_debitur' => $data['hub_calon_debitur'] ?? null,
|
|
'bandara' => $data['bandara'] ?? null,
|
|
'desa_kelurahan' => $data['desa_kelurahan'] ?? null,
|
|
'kecamatan' => $data['kecamatan'] ?? null,
|
|
'kota_madya' => $data['kota_madya'] ?? null,
|
|
'provinsi' => $data['provinsi'] ?? null,
|
|
|
|
'jenis_pesawat' => $data['jenis_pesawat'] ?? null,
|
|
'size' => $data['size'] ?? null,
|
|
'kondisi' => $data['kondisi'] ?? null,
|
|
'nama_pesawat' => $data['nama_pesawat'] ?? null,
|
|
'model' => $data['model'] ?? null,
|
|
'nomor_registrasi' => $data['nomor_registrasi'] ?? null,
|
|
'tahun_pembuatan' => $data['tahun_pembuatan'] ?? null,
|
|
'certificate_of_airworthines' => $data['certificate_of_airworthines'] ?? null,
|
|
'certificate_of_registration' => $data['certificate_of_registration'] ?? null,
|
|
'total_service_hours' => $data['total_service_hours'] ?? null,
|
|
'total_service_cycles' => $data['total_service_cycles'] ?? null,
|
|
|
|
'last_a_check' => $data['last_a_check'] ?? null,
|
|
'next_a_check' => $data['next_a_check'] ?? null,
|
|
'last_b_check' => $data['last_b_check'] ?? null,
|
|
'next_b_check' => $data['next_b_check'] ?? null,
|
|
'last_c_check' => $data['last_c_check'] ?? null,
|
|
'next_c_check' => $data['next_c_check'] ?? null,
|
|
'next_d_check' => $data['next_d_check'] ?? null,
|
|
'last_d_check' => $data['last_d_check'] ?? null,
|
|
'deskripsi_maintenence' => $data['deskripsi_maintenence'] ?? null,
|
|
|
|
'instrument_landing_system' => $data['instrument_landing_system'] ?? null,
|
|
'traffic_collision_avoidance_system' => $data['traffic_collision_avoidance_system'] ?? null,
|
|
'windshear' => $data['windshear'] ?? null,
|
|
'electronic_flight' => $data['electronic_flight'] ?? null,
|
|
'winglets' => $data['winglets'] ?? null,
|
|
'deskripsi_konfigurasi' => $data['deskripsi_konfigurasi'] ?? null,
|
|
|
|
'maksimal_penumpang' => $data['maksimal_penumpang'] ?? null,
|
|
'jumlah_kursi' => $data['jumlah_kursi'] ?? null,
|
|
'kursi_pramugari_pramugara' => $data['kursi_pramugari_pramugara'] ?? null,
|
|
'kartu_fitur_keselamatan' => $data['kartu_fitur_keselamatan'] ?? null,
|
|
'sabuk_pengaman' => $data['sabuk_pengaman'] ?? null,
|
|
'lampu_kabin' => $data['lampu_kabin'] ?? null,
|
|
'lampu_pintu_keluar' => $data['lampu_pintu_keluar'] ?? null,
|
|
'intercom_kabin' => $data['intercom_kabin'] ?? null,
|
|
'deskripsi_kabin' => $data['deskripsi_kabin'] ?? null,
|
|
|
|
'badan_pesawat' => $data['badan_pesawat'] ?? null,
|
|
'sayap_pesawat' => $data['sayap_pesawat'] ?? null,
|
|
'ekor_pesawat' => $data['ekor_pesawat'] ?? null,
|
|
'landing_gear' => $data['landing_gear'] ?? null,
|
|
'sistem_pengelasan' => $data['sistem_pengelasan'] ?? null,
|
|
'deskripsi_struktur' => $data['deskripsi_struktur'] ?? null,
|
|
|
|
'gps' => $data['gps'] ?? null,
|
|
'radar' => $data['radar'] ?? null,
|
|
'radio_komunikasi' => $data['radio_komunikasi'] ?? null,
|
|
'lampu_navigasi' => $data['lampu_navigasi'] ?? null,
|
|
'sistem_autopilot' => $data['sistem_autopilot'] ?? null,
|
|
'deskripsi_navigasi' => $data['deskripsi_navigasi'] ?? null,
|
|
|
|
'tangki_bahan_bakar' => $data['tangki_bahan_bakar'] ?? null,
|
|
'saluran_pipa_bahan_bakar' => $data['saluran_pipa_bahan_bakar'] ?? null,
|
|
'pompa_bahan_bakar' => $data['pompa_bahan_bakar'] ?? null,
|
|
'sistem_hidrolik_utama' => $data['sistem_hidrolik_utama'] ?? null,
|
|
'sistem_pendigin_hidrolik' => $data['sistem_pendigin_hidrolik'] ?? null,
|
|
'deskripsi_hidrolik' => $data['deskripsi_hidrolik'] ?? null,
|
|
|
|
'mesin_utama' => $data['mesin_utama'] ?? null,
|
|
'sistem_pendorong' => $data['sistem_pendorong'] ?? null,
|
|
'sistem_pendigin_mesin' => $data['sistem_pendigin_mesin'] ?? null,
|
|
'sistem_pelumasan' => $data['sistem_pelumasan'] ?? null,
|
|
'filter_dan_perangkat_pendukung' => $data['filter_dan_perangkat_pendukung'] ?? null,
|
|
'deskripsi_kondisi_mesin' => $data['deskripsi_kondisi_mesin'] ?? null,
|
|
|
|
'jaket_pelampung' => $data['jaket_pelampung'] ?? null,
|
|
'pintu_darurat' => $data['pintu_darurat'] ?? null,
|
|
'alat_pemadaman_kebakaran' => $data['alat_pemadaman_kebakaran'] ?? null,
|
|
'sistem_alaram_darurat' => $data['sistem_alaram_darurat'] ?? null,
|
|
'sekoci' => $data['sekoci'] ?? null,
|
|
'masker_oxigen' => $data['masker_oxigen'] ?? null,
|
|
'sabuk_pengaman' => $data['sabuk_pengaman'] ?? null,
|
|
'deskripsi_fungsi_keselamatan' => $data['deskripsi_fungsi_keselamatan'] ?? null,
|
|
|
|
'sistem_ventilasi_ac' => $data['sistem_ventilasi_ac'] ?? null,
|
|
'sistem_penerangan_kabin' => $data['sistem_penerangan_kabin'] ?? null,
|
|
'panel_informasi_penumpang' => $data['panel_informasi_penumpang'] ?? null,
|
|
'sistem_hiburan_kabin' => $data['sistem_hiburan_kabin'] ?? null,
|
|
'deskripsi_Interior' => $data['deskripsi_Interior'] ?? null,
|
|
|
|
// Validasi untuk faktor dan kesimpulan
|
|
'faktor_positif' => $data['faktor_positif'] ?? null,
|
|
'faktor_negatif' => $data['faktor_negatif'] ?? null,
|
|
'kesimpulan' => $data['kesimpulan'] ?? null,
|
|
'catatan' => $data['catatan'] ?? null,
|
|
];
|
|
}
|
|
|
|
|
|
|
|
|
|
private function getUnitData($data, $request): array
|
|
{
|
|
return [
|
|
'action' => $data['action'] ?? null,
|
|
'luas_unit' => $this->getFieldData(
|
|
$data,
|
|
'luas_unit',
|
|
true
|
|
),
|
|
'kondisi_unit' => $data['kondisi_unit'] ?? null,
|
|
'posisi_unit' => $data['posisi_unit'] ?? null,
|
|
'lantai' => $data['lantai'] ?? null,
|
|
'view' => $data['view'] ?? null,
|
|
'bentuk_unit' => $data['bentuk_unit'] ?? null,
|
|
];
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
* Helper untuk upload file
|
|
*
|
|
* @param $file
|
|
* @param $type
|
|
* @return path name
|
|
*/
|
|
|
|
|
|
private function uploadFile($file, $type)
|
|
{
|
|
if (!$file->isValid()) {
|
|
throw new Exception("Invalid file upload for {$type}");
|
|
}
|
|
|
|
$fileName = time() . '_' . $file->getClientOriginalName();
|
|
$path = $file->storeAs("public/surveyor/{$type}", $fileName);
|
|
|
|
if ($path === false) {
|
|
throw new Exception("Failed to store file for {$type}");
|
|
}
|
|
|
|
return str_replace('public/', '', $path);
|
|
}
|
|
|
|
|
|
/**
|
|
* Helper untuk memetakan array dengan inputannya
|
|
*
|
|
* @param array $keys Array kunci
|
|
* @param array $values Array nilai/input
|
|
* @return array
|
|
*/
|
|
private function mapArrayWithInputs(array $keys, array $values): array
|
|
{
|
|
$result = [];
|
|
|
|
foreach ($keys as $index => $key) {
|
|
$result[$key] = $values[$index] ?? null;
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
* Helper method generic untuk mengambil data field
|
|
*
|
|
* @param array $data Array sumber data
|
|
* @param string $fieldName Nama field
|
|
* @param bool $checkKesesuaian Apakah perlu cek kesesuaian
|
|
* @param string|null $extraField Field tambahan (misal 'lainnya')
|
|
* @return array
|
|
*/
|
|
private function getFieldData(
|
|
array $data,
|
|
string $fieldName,
|
|
bool $checkKesesuaian = false,
|
|
?string $extraField = null
|
|
): array {
|
|
if ($checkKesesuaian) {
|
|
return [
|
|
$data[$fieldName] ?? '' => ($data[$fieldName] ?? '') === 'sesuai'
|
|
? ($data["{$fieldName}_sesuai"] ?? '')
|
|
: ($data["{$fieldName}_tidak_sesuai"] ?? '')
|
|
];
|
|
}
|
|
|
|
$result = [
|
|
$fieldName => $data[$fieldName] ?? null
|
|
];
|
|
|
|
if ($extraField) {
|
|
$result[$extraField] = $data["{$fieldName}_{$extraField}"] ?? null;
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
|
|
public function export(string $type)
|
|
{
|
|
$modelClass = $this->getModelClass($type);
|
|
|
|
if (!$modelClass) {
|
|
|
|
return response()->json([
|
|
'message' => 'Invalid type provided.',
|
|
'available_types' => array_keys($this->modelClasses),
|
|
], 400);
|
|
}
|
|
|
|
// Return Excel download
|
|
return Excel::download(new BasicDataSurveyorExport($modelClass), $type . '.xlsx');
|
|
}
|
|
}
|