Merge branch 'staging' of https://git.putrakuningan.com/daengdeni/lpj into andydev
This commit is contained in:
@@ -2,21 +2,22 @@
|
||||
|
||||
namespace Modules\Lpj\Exports;
|
||||
|
||||
// use Maatwebsite\Excel\Concerns\FromCollection;
|
||||
// use Maatwebsite\Excel\Concerns\WithColumnFormatting;
|
||||
// use PhpOffice\PhpSpreadsheet\Worksheet\Worksheet;
|
||||
// use Maatwebsite\Excel\Concerns\WithHeadings;
|
||||
// use Maatwebsite\Excel\Concerns\WithStyles;
|
||||
// use Maatwebsite\Excel\Concerns\WithColumnWidths;
|
||||
// use Maatwebsite\Excel\Concerns\WithEvents;
|
||||
// use Maatwebsite\Excel\Events\AfterSheet;
|
||||
use Illuminate\Contracts\View\View;
|
||||
use Maatwebsite\Excel\Concerns\FromView;
|
||||
class KertasKerjaExport implements FromView
|
||||
{
|
||||
use Maatwebsite\Excel\Concerns\FromCollection;
|
||||
use Maatwebsite\Excel\Concerns\WithHeadings;
|
||||
use Maatwebsite\Excel\Concerns\WithStyles;
|
||||
use Maatwebsite\Excel\Concerns\WithColumnWidths;
|
||||
use Maatwebsite\Excel\Concerns\WithEvents;
|
||||
use Maatwebsite\Excel\Events\AfterSheet;
|
||||
use PhpOffice\PhpSpreadsheet\Worksheet\Worksheet;
|
||||
use PhpOffice\PhpSpreadsheet\Worksheet\Drawing;
|
||||
|
||||
// class KertasKerjaExport implements FromCollection, WithHeadings, WithStyles, WithColumnWidths, WithEvents
|
||||
class KertasKerjaExport implements FromCollection, WithHeadings, WithStyles, WithColumnWidths, WithEvents
|
||||
{
|
||||
// use Illuminate\Contracts\View\View;
|
||||
// use Maatwebsite\Excel\Concerns\FromView;
|
||||
// class KertasKerjaExport implements FromView
|
||||
// {
|
||||
|
||||
protected $data;
|
||||
|
||||
public function __construct($data)
|
||||
@@ -24,257 +25,315 @@ class KertasKerjaExport implements FromView
|
||||
$this->data = $data;
|
||||
}
|
||||
|
||||
public function view(): View
|
||||
{
|
||||
return view('lpj::component.kertas-kerja', [
|
||||
'data' => $this->data,
|
||||
]);
|
||||
}
|
||||
|
||||
// public function collection()
|
||||
// public function view(): View
|
||||
// {
|
||||
// return view('lpj::component.kertas-kerja', [
|
||||
// 'data' => $this->data,
|
||||
// ]);
|
||||
// }
|
||||
|
||||
public function collection()
|
||||
{
|
||||
// $rows = [];
|
||||
|
||||
// $nomor = 1;
|
||||
// $fields = [
|
||||
// 'jenis_aset' => 'Jenis Aset',
|
||||
// 'luas_tanah' => 'Luas Tanah (M²)',
|
||||
// 'luas_bangunan' => 'Luas Bangunan (M²)',
|
||||
// 'harga' => 'Harga Transaksi/Penawaran',
|
||||
// 'tanggal_penawaran' => 'Tanggal Penawaran/Transaksi',
|
||||
// 'diskon' => 'Diskon %',
|
||||
// 'esitmasi_harga' => 'Esitmasi Harga Transaksi (Rp)',
|
||||
// 'no_telepon' => 'Telepon Contact Person',
|
||||
// 'nama_nara_sumbr' => 'Nama Nara Sumber',
|
||||
// 'status_nara_sumbr' => 'Status Nara Sumber',
|
||||
// 'waktu_transaksi' => 'Waktu Transaksi/Penawaran',
|
||||
// 'alamat' => 'Alamat Titik Gps',
|
||||
$fields = [
|
||||
'jenis_aset' => 'Jenis Aset',
|
||||
'luas_tanah' => 'Luas Tanah (M²)',
|
||||
'luas_bangunan' => 'Luas Bangunan (M²)',
|
||||
'harga' => 'Harga Transaksi/Penawaran',
|
||||
'tanggal_penawaran' => 'Tanggal Penawaran/Transaksi',
|
||||
'diskon' => 'Diskon %',
|
||||
'esitmasi_harga' => 'Esitmasi Harga Transaksi (Rp)',
|
||||
'no_telepon' => 'Telepon Contact Person',
|
||||
'nama_nara_sumbr' => 'Nama Nara Sumber',
|
||||
'status_nara_sumbr' => 'Status Nara Sumber',
|
||||
'waktu_transaksi' => 'Waktu Transaksi/Penawaran',
|
||||
'alamat' => 'Alamat Titik Gps',
|
||||
|
||||
// 'jalan' => 'Jalan',
|
||||
// 'desa' => 'Desa/Kelurahan',
|
||||
// 'kecamatan' => 'Kecamatan',
|
||||
// 'kabupaten' => 'Kabupaten',
|
||||
// 'provinsi' => 'Provinsi',
|
||||
'jalan' => 'Jalan',
|
||||
'desa' => 'Desa/Kelurahan',
|
||||
'kecamatan' => 'Kecamatan',
|
||||
'kabupaten' => 'Kabupaten',
|
||||
'provinsi' => 'Provinsi',
|
||||
|
||||
// 'jarak_pembanding' => 'Jarak Pembanding dengan Objek',
|
||||
// 'elevasi' => 'Estimasi Ranking Tanah',
|
||||
// 'peruntukan' => 'Estiamsi Rangkin Bangunan'
|
||||
'jarak_pembanding' => 'Jarak Pembanding dengan Objek',
|
||||
'elevasi' => 'Estimasi Ranking Tanah',
|
||||
'peruntukan' => 'Estiamsi Rangkin Bangunan'
|
||||
|
||||
// ];
|
||||
];
|
||||
|
||||
// foreach ($fields as $key => $label) {
|
||||
// $rows[] = [
|
||||
// $nomor++,
|
||||
// $label,
|
||||
// $this->data['objek'][$key] ?? '',
|
||||
// $this->data['pembanding1'][$key] ?? '',
|
||||
// $this->data['pembanding2'][$key] ?? '',
|
||||
// $this->data['pembanding3'][$key] ?? ''
|
||||
// ];
|
||||
// }
|
||||
$rows = [];
|
||||
$nomor = 1;
|
||||
|
||||
// // B. Perhitungan Penyesuaian
|
||||
// $rows[] = [''];
|
||||
// $rows[] = [''];
|
||||
// $rows[] = ['B. Estimasi Nilai Tanah Pembanding dengan Teknik Penyisaan Tanah untuk mendapatkan per meter persegi estimasi Nilai Tanah Pembanding'];
|
||||
// $rows[] = ['No.','Uraian', 'Objek Penilaian', 'Data Pembanding 1', 'Data Pembanding 2', 'Data Pembanding 3'];
|
||||
// $nostimasi = 1;
|
||||
// $filedEstimasi = [
|
||||
// 'estimasi' => 'Estimasi Biaya Pengganti Baru Bangunan (Rp)',
|
||||
// 'estimasi_spl' => 'Estimasi Biaya Pengganti Baru SPL (Rp)',
|
||||
// 'penyusutan' => 'Penyusutan Fisik Banguna',
|
||||
// Add general asset information
|
||||
$rows[] = ['No.', 'Uraian', 'Objek Penilaian', 'Data Pembanding 1', 'Data Pembanding 2', 'Data Pembanding 3'];
|
||||
|
||||
// 'a' => 'a. rincian ttipe bangunan (MAPPI)',
|
||||
// 'b' => 'b. umur ekonomis (MAPPI)',
|
||||
// 'c' => 'c. estimasi Tahun tahun visual dengan mempertimbangkan renovasi',
|
||||
// 'd' => 'd. Sehingga sisa umur efektif',
|
||||
// 'e' => 'e. kondisi bagunan',
|
||||
// 'f' => 'f.sehinggan penyusutan fisik',
|
||||
// 'penyusutan_fungsi' => 'Penyusutan fungsi Bangunan (%)',
|
||||
// 'penyusutan_ekonomi' => 'Penyusutan Ekonomi Bangunan (%)',
|
||||
// 'total_penyusutan' => 'Total Penyusutan (%)',
|
||||
// 'estimasi_nilai' => 'Estimasi Nilai Bangunan dan SPL (Rp)',
|
||||
// 'estimasi_tanah' => 'Estimasi Nilai Tanah Pembanding (Rp)',
|
||||
// 'estimasi_nilai' => 'Estimasi Nilai Tanah Pembanding (Rp)',
|
||||
// ];
|
||||
|
||||
// foreach ($filedEstimasi as $key => $label) {
|
||||
// $rows[] = [
|
||||
// $nostimasi++,
|
||||
// $label,
|
||||
// $this->data['estimasi'][$key] ?? '',
|
||||
// $this->data['estimasi1'][$key] ?? '',
|
||||
// $this->data['estimasi2'][$key] ?? '',
|
||||
// $this->data['estimasi3'][$key] ?? ''
|
||||
|
||||
// ];
|
||||
// }
|
||||
foreach ($this->data['objek'] as $key => $value) {
|
||||
$rows[] = [
|
||||
$nomor++,
|
||||
$key,
|
||||
$value,
|
||||
$this->data['pembanding1'][$key] ?? '',
|
||||
$this->data['pembanding2'][$key] ?? '',
|
||||
$this->data['pembanding3'][$key] ?? ''
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
// $row[] = [''];
|
||||
// $row[] = [''];
|
||||
// $rows[] = ['INDIKASI NILAI TANAHATAS OBJEK PENILAIAN'];
|
||||
// B. Perhitungan Penyesuaian
|
||||
$rows[] = [''];
|
||||
$rows[] = [''];
|
||||
$rows[] = ['B. Estimasi Nilai Tanah Pembanding dengan Teknik Penyisaan Tanah untuk mendapatkan per meter persegi estimasi Nilai Tanah Pembanding'];
|
||||
$rows[] = ['No.','Uraian', 'Objek Penilaian', 'Data Pembanding 1', 'Data Pembanding 2', 'Data Pembanding 3'];
|
||||
$nostimasi = 1;
|
||||
$filedEstimasi = [
|
||||
'estimasi' => 'Estimasi Biaya Pengganti Baru Bangunan (Rp)',
|
||||
'estimasi_spl' => 'Estimasi Biaya Pengganti Baru SPL (Rp)',
|
||||
'penyusutan' => 'Penyusutan Fisik Banguna',
|
||||
|
||||
// $indikasi=[
|
||||
// 'luas_tanah' => 'Luas Tanah ',
|
||||
// 'indikasi_per' => 'INDIKASI TANAH PER M2 (RP/M2)',
|
||||
// 'indikasi_total' => 'INDIKASI TANAH TOTAL(RP)',
|
||||
// 'varian' => 'VARIANT(%)',
|
||||
// ];
|
||||
'a' => 'a. rincian ttipe bangunan (MAPPI)',
|
||||
'b' => 'b. umur ekonomis (MAPPI)',
|
||||
'c' => 'c. estimasi Tahun tahun visual dengan mempertimbangkan renovasi',
|
||||
'd' => 'd. Sehingga sisa umur efektif',
|
||||
'e' => 'e. kondisi bagunan',
|
||||
'f' => 'f.sehinggan penyusutan fisik',
|
||||
'penyusutan_fungsi' => 'Penyusutan fungsi Bangunan (%)',
|
||||
'penyusutan_ekonomi' => 'Penyusutan Ekonomi Bangunan (%)',
|
||||
'total_penyusutan' => 'Total Penyusutan (%)',
|
||||
'estimasi_nilai' => 'Estimasi Nilai Bangunan dan SPL (Rp)',
|
||||
'estimasi_tanah' => 'Estimasi Nilai Tanah Pembanding (Rp)',
|
||||
'estimasi_nilai' => 'Estimasi Nilai Tanah Pembanding (Rp)',
|
||||
];
|
||||
|
||||
// foreach ($indikasi as $key => $label) {
|
||||
// $rows[] = [
|
||||
// $label,
|
||||
// $this->data['indikasi'][$key] ?? '',
|
||||
// ];
|
||||
// }
|
||||
foreach ($filedEstimasi as $key => $label) {
|
||||
$rows[] = [
|
||||
$nostimasi++,
|
||||
$label,
|
||||
$this->data['estimasi'][$key] ?? '',
|
||||
$this->data['estimasi1'][$key] ?? '',
|
||||
$this->data['estimasi2'][$key] ?? '',
|
||||
$this->data['estimasi3'][$key] ?? ''
|
||||
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
// // C. Peta Lokasi
|
||||
// $rows[] = [''];
|
||||
// $rows[] = [''];
|
||||
// $rows[] = ['C. Peta Lokasi'];
|
||||
// $rows[] = [$this->data['foto_objek']['foto_objek_peta'] ?? ''];
|
||||
$row[] = [''];
|
||||
$row[] = [''];
|
||||
$rows[] = ['INDIKASI NILAI TANAHATAS OBJEK PENILAIAN'];
|
||||
|
||||
// // D. Foto Objek dan Data Pembanding
|
||||
// $rows[] = [''];
|
||||
// $rows[] = ['D. Foto Objek dan Data Pembanding'];
|
||||
// $rows[] = [
|
||||
// $this->data['foto_objek1']['foto_objek'] ?? '',
|
||||
// $this->data['foto_objek2']['foto_objek'] ?? '',
|
||||
// '', '', ''
|
||||
// ];
|
||||
$indikasi=[
|
||||
'luas_tanah' => 'Luas Tanah ',
|
||||
'indikasi_per' => 'INDIKASI TANAH PER M2 (RP/M2)',
|
||||
'indikasi_total' => 'INDIKASI TANAH TOTAL(RP)',
|
||||
'varian' => 'VARIANT(%)',
|
||||
];
|
||||
|
||||
// // E. Foto Objek
|
||||
// $rows[] = [''];
|
||||
// $rows[] = ['E. Foto Objek'];
|
||||
// $rows[] = [
|
||||
// $this->data['foto']['foto_objek'] ?? '',
|
||||
// $this->data['foto']['foto_objek'] ?? '',
|
||||
// '', '', ''
|
||||
// ];
|
||||
|
||||
// return collect($rows);
|
||||
// }
|
||||
|
||||
// public function headings(): array
|
||||
// {
|
||||
// return [
|
||||
// ['KERTAS KERJA PENILAIAN'],
|
||||
// ['Pendekatan Pasar'],
|
||||
// ['Metode Perbandingan Data Pasar'],
|
||||
// ['Tanggal Penilaian: ' . ($this->headerInfo['tanggal_penilaian'] ?? '')],
|
||||
// ['Nama Pemilik Aset: ' . ($this->headerInfo['nama_pemilik'] ?? '')],
|
||||
// ['Nama Pemberi Tugas: ' . ($this->headerInfo['nama_pemberi_tugas'] ?? '')],
|
||||
// ['Lokasi: ' . ($this->headerInfo['lokasi_lengkap'] ?? '')],
|
||||
// ['Nama Debitur: ' . ($this->headerInfo['nama_debitur'] ?? '')],
|
||||
// [''],
|
||||
// ['A. INFORMASI UMUM'],
|
||||
// ['No.','Uraian', 'Objek Penilaian', 'Data Pembanding 1', 'Data Pembanding 2', 'Data Pembanding 3']
|
||||
foreach ($indikasi as $key => $label) {
|
||||
$rows[] = [
|
||||
$label,
|
||||
$this->data['indikasi'][$key] ?? '',
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
// ];
|
||||
// }
|
||||
// public function registerEvents(): array
|
||||
// {
|
||||
// return [
|
||||
// AfterSheet::class => function (AfterSheet $event) {
|
||||
// // Styling untuk header utama
|
||||
// C. Peta Lokasi
|
||||
$rows[] = [''];
|
||||
$rows[] = [''];
|
||||
$rows[] = ['C. Peta Lokasi'];
|
||||
$rows[] = [$this->data['foto_objek']['foto_objek_peta'] ?? ''];
|
||||
|
||||
// D. Foto Objek dan Data Pembanding
|
||||
$rows[] = [''];
|
||||
$rows[] = ['D. Foto Objek dan Data Pembanding'];
|
||||
$rows[] = [
|
||||
$this->data['foto_objek1']['foto_objek'] ?? '',
|
||||
$this->data['foto_objek2']['foto_objek'] ?? '',
|
||||
'', '', ''
|
||||
];
|
||||
|
||||
// E. Foto Objek
|
||||
$rows[] = [''];
|
||||
$rows[] = ['E. Foto Objek'];
|
||||
$rows[] = [
|
||||
$this->data['foto']['foto_objek'] ?? '',
|
||||
$this->data['foto']['foto_objek'] ?? '',
|
||||
'', '', ''
|
||||
];
|
||||
|
||||
return collect($rows);
|
||||
}
|
||||
|
||||
public function headings(): array
|
||||
{
|
||||
return [
|
||||
['KERTAS KERJA PENILAIAN'],
|
||||
['Pendekatan Pasar'],
|
||||
['Metode Perbandingan Data Pasar'],
|
||||
['Tanggal Penilaian: ' . ($this->headerInfo['tanggal_penilaian'] ?? '')],
|
||||
['Nama Pemilik Aset: ' . ($this->headerInfo['nama_pemilik'] ?? '')],
|
||||
['Nama Pemberi Tugas: ' . ($this->headerInfo['nama_pemberi_tugas'] ?? '')],
|
||||
['Lokasi: ' . ($this->headerInfo['lokasi_lengkap'] ?? '')],
|
||||
|
||||
];
|
||||
}
|
||||
public function registerEvents(): array
|
||||
{
|
||||
return [
|
||||
AfterSheet::class => function (AfterSheet $event) {
|
||||
// Styling untuk header utama
|
||||
|
||||
|
||||
// // Styling untuk setiap section header
|
||||
// $sectionRows = [10, 34, 56, 46, 52]; // Sesuaikan dengan posisi setiap section
|
||||
// foreach ($sectionRows as $row) {
|
||||
// $event->sheet->getStyle("A{$row}:F{$row}")->getFill()
|
||||
// ->setFillType(\PhpOffice\PhpSpreadsheet\Style\Fill::FILL_SOLID)
|
||||
// ->getStartColor()->setRGB('E2EFDA');
|
||||
// }
|
||||
// Styling untuk setiap section header
|
||||
$sectionRows = [10, 34, 56, 46, 52]; // Sesuaikan dengan posisi setiap section
|
||||
foreach ($sectionRows as $row) {
|
||||
$event->sheet->getStyle("A{$row}:F{$row}")->getFill()
|
||||
->setFillType(\PhpOffice\PhpSpreadsheet\Style\Fill::FILL_SOLID)
|
||||
->getStartColor()->setRGB('E2EFDA');
|
||||
}
|
||||
|
||||
// // Merge cells untuk headers
|
||||
// $event->sheet->mergeCells('A1:E1');
|
||||
// $event->sheet->mergeCells('A2:E2');
|
||||
// $event->sheet->mergeCells('A4:E4');
|
||||
// $event->sheet->mergeCells('A5:E5');
|
||||
// $event->sheet->mergeCells('A6:E6');
|
||||
// $event->sheet->mergeCells('A7:E7');
|
||||
// $event->sheet->mergeCells('A8:E8');
|
||||
// Merge cells untuk headers
|
||||
$event->sheet->mergeCells('A1:E1');
|
||||
$event->sheet->mergeCells('A2:E2');
|
||||
$event->sheet->mergeCells('A4:E4');
|
||||
$event->sheet->mergeCells('A5:E5');
|
||||
$event->sheet->mergeCells('A6:E6');
|
||||
$event->sheet->mergeCells('A7:E7');
|
||||
$event->sheet->mergeCells('A8:E8');
|
||||
|
||||
// // Alignment
|
||||
// $event->sheet->getStyle('A1:E8')->getAlignment()
|
||||
// ->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_LEFT);
|
||||
// }
|
||||
// ];
|
||||
// }
|
||||
// public function columnWidths(): array
|
||||
// {
|
||||
// return [
|
||||
// 'A' => 5,
|
||||
// 'B' => 30,
|
||||
// 'C' => 30,
|
||||
// 'D' => 30,
|
||||
// 'E' => 30,
|
||||
// 'F' => 30,
|
||||
// ];
|
||||
// }
|
||||
// Alignment
|
||||
$event->sheet->getStyle('A1:E8')->getAlignment()
|
||||
->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_LEFT);
|
||||
$this->insertImages($event->sheet);
|
||||
}
|
||||
];
|
||||
}
|
||||
public function columnWidths(): array
|
||||
{
|
||||
return [
|
||||
'A' => 5,
|
||||
'B' => 30,
|
||||
'C' => 30,
|
||||
'D' => 30,
|
||||
'E' => 30,
|
||||
'F' => 30,
|
||||
];
|
||||
}
|
||||
|
||||
// public function styles(Worksheet $sheet)
|
||||
// {
|
||||
// return [
|
||||
// // Style for the main header
|
||||
public function styles(Worksheet $sheet)
|
||||
{
|
||||
return [
|
||||
// Style for the main header
|
||||
|
||||
// // Style for section headers
|
||||
// 10 => ['font' => ['bold' => true]], // A. Informasi Umum
|
||||
// 34 => ['font' => ['bold' => true]], // B. Estimasi Nilai Tanah
|
||||
// 35 => ['font' => ['bold' => true]], // C. Peta Lokasi
|
||||
// 57 => ['font' => ['bold' => true]], // D. Foto Objek dan Pembanding
|
||||
// 60 => ['font' => ['bold' => true]], // E. Foto Objek
|
||||
// Style for section headers
|
||||
10 => ['font' => ['bold' => true]], // A. Informasi Umum
|
||||
34 => ['font' => ['bold' => true]], // B. Estimasi Nilai Tanah
|
||||
35 => ['font' => ['bold' => true]], // C. Peta Lokasi
|
||||
57 => ['font' => ['bold' => true]], // D. Foto Objek dan Pembanding
|
||||
60 => ['font' => ['bold' => true]], // E. Foto Objek
|
||||
|
||||
// // Default styling for columns
|
||||
// 'A:J' => [
|
||||
// 'alignment' => ['horizontal' => 'left', 'vertical' => 'center'],
|
||||
// 'wrapText' => true,
|
||||
// ],
|
||||
// Default styling for columns
|
||||
'A:J' => [
|
||||
'alignment' => ['horizontal' => 'left', 'vertical' => 'center'],
|
||||
'wrapText' => true,
|
||||
],
|
||||
|
||||
// // Style for other sections (like photo and map sections)
|
||||
// Style for other sections (like photo and map sections)
|
||||
|
||||
// // Style for the other headers
|
||||
// 'A11:F11' => [
|
||||
// 'font' => ['bold' => true],
|
||||
// 'fill' => ['fillType' => 'solid', 'color' => ['rgb' => 'E2EFDA']],
|
||||
// 'borders' => [
|
||||
// 'allBorders' => [
|
||||
// 'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN
|
||||
// ]
|
||||
// ]
|
||||
// ],
|
||||
// 'A12:F31' => [
|
||||
// 'borders' => [
|
||||
// 'allBorders' => [
|
||||
// 'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN
|
||||
// ]
|
||||
// ]
|
||||
// ],
|
||||
// Style for the other headers
|
||||
'A11:F11' => [
|
||||
'font' => ['bold' => true],
|
||||
'fill' => ['fillType' => 'solid', 'color' => ['rgb' => 'E2EFDA']],
|
||||
'borders' => [
|
||||
'allBorders' => [
|
||||
'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN
|
||||
]
|
||||
]
|
||||
],
|
||||
'A12:F31' => [
|
||||
'borders' => [
|
||||
'allBorders' => [
|
||||
'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN
|
||||
]
|
||||
]
|
||||
],
|
||||
|
||||
|
||||
// 'A35:F35' => [
|
||||
// 'font' => ['bold' => true],
|
||||
// 'fill' => ['fillType' => 'solid', 'color' => ['rgb' => 'E2EFDA']],
|
||||
// 'borders' => [
|
||||
// 'allBorders' => [
|
||||
// 'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN
|
||||
// ]
|
||||
// ]
|
||||
// ],
|
||||
// 'A35:F49' => [
|
||||
// 'borders' => [
|
||||
// 'allBorders' => [
|
||||
// 'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN
|
||||
// ]
|
||||
// ]
|
||||
// ],
|
||||
'A35:F35' => [
|
||||
'font' => ['bold' => true],
|
||||
'fill' => ['fillType' => 'solid', 'color' => ['rgb' => 'E2EFDA']],
|
||||
'borders' => [
|
||||
'allBorders' => [
|
||||
'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN
|
||||
]
|
||||
]
|
||||
],
|
||||
'A35:F49' => [
|
||||
'borders' => [
|
||||
'allBorders' => [
|
||||
'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN
|
||||
]
|
||||
]
|
||||
],
|
||||
|
||||
// end header
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
protected function insertImages($sheet)
|
||||
{
|
||||
ini_set('max_execution_time', '300');
|
||||
|
||||
$worksheet = $sheet->getDelegate();
|
||||
|
||||
// Insert images for pembanding1
|
||||
if (!empty($this->data['pembanding1']['foto_objek'])) {
|
||||
$drawing = new Drawing();
|
||||
$drawing->setName('Pembanding 1');
|
||||
$drawing->setDescription('Foto Objek Pembanding 1');
|
||||
$drawing->setPath(storage_path('app/public/' . $this->data['pembanding1']['foto_objek'])); // Adjust path as needed
|
||||
$drawing->setHeight(90);
|
||||
$drawing->setCoordinates('C' . (count($this->collection()) + 2)); // Adjust coordinates as needed
|
||||
$drawing->setWorksheet($worksheet);
|
||||
}
|
||||
|
||||
// Repeat for pembanding2 and pembanding3
|
||||
if (!empty($this->data['pembanding2']['foto_objek'])) {
|
||||
$drawing = new Drawing();
|
||||
$drawing->setName('Pembanding 2');
|
||||
$drawing->setDescription('Foto Objek Pembanding 2');
|
||||
$drawing->setPath(storage_path('app/public/' . $this->data['pembanding2']['foto_objek'])); // Adjust path as needed
|
||||
$drawing->setHeight(90);
|
||||
$drawing->setCoordinates('C' . (count($this->collection()) + 4)); // Adjust coordinates as needed
|
||||
$drawing->setWorksheet($worksheet);
|
||||
}
|
||||
|
||||
if (!empty($this->data['pembanding3']['foto_objek'])) {
|
||||
$drawing = new Drawing();
|
||||
$drawing->setName('Pembanding 3');
|
||||
$drawing->setDescription('Foto Objek Pembanding 3');
|
||||
$drawing->setPath(storage_path('app/public/' . $this->data['pembanding3']['foto_objek'])); // Adjust path as needed
|
||||
$drawing->setHeight(90);
|
||||
$drawing->setCoordinates('C' . (count($this->collection()) + 6)); // Adjust coordinates as needed
|
||||
$drawing->setWorksheet($worksheet);
|
||||
}
|
||||
|
||||
// Insert images for foto_objek
|
||||
foreach ($this->data['foto_objek'] as $index => $foto) {
|
||||
if (!empty($foto['foto_objek'])) {
|
||||
$drawing = new Drawing();
|
||||
$drawing->setName($foto['name_objek']);
|
||||
$drawing->setDescription($foto['deskripsi_objek']);
|
||||
$drawing->setPath(storage_path('app/public/' . $foto['foto_objek'])); // Adjust path as needed
|
||||
$drawing->setHeight(90);
|
||||
$drawing->setCoordinates('C' . (count($this->collection()) + (8 + $index * 2))); // Adjust coordinates as needed
|
||||
$drawing->setWorksheet($worksheet);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// // end header
|
||||
// ];
|
||||
// }
|
||||
|
||||
}
|
||||
|
||||
147
app/Http/Controllers/PembatalanController.php
Normal file
147
app/Http/Controllers/PembatalanController.php
Normal file
@@ -0,0 +1,147 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Lpj\Http\Controllers;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use Barryvdh\DomPDF\Facade\Pdf;
|
||||
use Exception;
|
||||
use Illuminate\Http\Request;
|
||||
use Maatwebsite\Excel\Facades\Excel;
|
||||
use Modules\Location\Models\City;
|
||||
use Modules\Location\Models\District;
|
||||
use Modules\Location\Models\Province;
|
||||
use Modules\Location\Models\Village;
|
||||
use Modules\Lpj\Exports\PermohonanExport;
|
||||
use Modules\Lpj\Http\Requests\PermohonanRequest;
|
||||
use Modules\Lpj\Models\Branch;
|
||||
use Modules\Lpj\Models\Debiture;
|
||||
use Modules\Lpj\Models\DokumenJaminan;
|
||||
use Modules\Lpj\Models\JenisFasilitasKredit;
|
||||
use Modules\Lpj\Models\NilaiPlafond;
|
||||
use Modules\Lpj\Models\Permohonan;
|
||||
use Modules\Lpj\Models\PermohonanPembatalan;
|
||||
use Modules\Lpj\Models\StatusPermohonan;
|
||||
use Modules\Lpj\Models\TujuanPenilaian;
|
||||
use Modules\Lpj\Services\PermohonanHistoryService;
|
||||
|
||||
class PembatalanController extends Controller
|
||||
{
|
||||
public $user;
|
||||
protected $historyService;
|
||||
|
||||
public function __construct(PermohonanHistoryService $historyService)
|
||||
{
|
||||
$this->historyService = $historyService;
|
||||
}
|
||||
|
||||
public function index()
|
||||
{
|
||||
return view('lpj::pembatalan.index');
|
||||
}
|
||||
|
||||
public function edit($id)
|
||||
{
|
||||
$pembatalan = PermohonanPembatalan::with(['permohonan.debiture','permohonan.branch'])->find($id);
|
||||
|
||||
return view(
|
||||
'lpj::pembatalan.form',
|
||||
compact(
|
||||
'pembatalan'
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
$pembatalan = PermohonanPembatalan::findOrFail($id);
|
||||
$permohonan = Permohonan::find($pembatalan->permohonan_id);
|
||||
$beforeRequest = $permohonan->toArray();
|
||||
|
||||
try {
|
||||
// Update Permohonan Pembatalan
|
||||
if($request->status=='approved'){
|
||||
$pembatalan->status = 'approved';
|
||||
$pembatalan->save();
|
||||
|
||||
$permohonan->status = 'batal';
|
||||
$permohonan->save();
|
||||
} else{
|
||||
$pembatalan->status = 'rejected';
|
||||
$pembatalan->save();
|
||||
}
|
||||
|
||||
return redirect()
|
||||
->route('pembatalan.index')->with('success', 'Permohonan Pembatalan updated successfully');
|
||||
} catch (Exception $e) {
|
||||
return redirect()
|
||||
->route('pembatalan.edit', $id)->with('error', 'Failed to update permohonan Pembatalan');
|
||||
}
|
||||
}
|
||||
|
||||
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.');
|
||||
}
|
||||
|
||||
// Retrieve data from the database
|
||||
$query = PermohonanPembatalan::query();
|
||||
$query = $query->orderBy('created_at', 'desc');
|
||||
// Apply search filter if provided
|
||||
if ($request->has('search') && !empty($request->get('search'))) {
|
||||
$search = $request->get('search');
|
||||
$query->where(function ($q) use ($search) {
|
||||
$q->orWhereRelation('permohonan', 'nomor_registrasi', 'LIKE', '%' . $search . '%');
|
||||
$q->orWhereRelation('permohonan.debiture', 'name', 'LIKE', '%' . $search . '%');
|
||||
$q->orWhere('alasan_pembatalan', 'LIKE', '%' . $search . '%');
|
||||
$q->orWhere('status', '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();
|
||||
$size = $request->get('size', 10);
|
||||
if ($size == 0) {
|
||||
$size = 10;
|
||||
}
|
||||
|
||||
// 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->with(['permohonan.debiture','permohonan.branch','creator'])->get();
|
||||
|
||||
// Calculate the page count
|
||||
$pageCount = ceil($totalRecords / $size);
|
||||
|
||||
// Calculate the current page number
|
||||
$currentPage = max(1, $request->get('page', 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,
|
||||
]);
|
||||
}
|
||||
}
|
||||
@@ -3,6 +3,7 @@
|
||||
namespace Modules\Lpj\Http\Controllers;
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
use Barryvdh\DomPDF\Facade\Pdf; // https://github.com/barryvdh/laravel-dompdf
|
||||
use Modules\Lpj\Models\Permohonan;
|
||||
use Modules\Lpj\Models\Inspeksi;
|
||||
use Modules\Lpj\Models\Penilai;
|
||||
@@ -12,7 +13,6 @@ use Maatwebsite\Excel\Facades\Excel;
|
||||
use Modules\Lpj\Exports\KertasKerjaExport;
|
||||
use Modules\Lpj\Http\Controllers\SurveyorController;
|
||||
use Modules\Location\Models\Province;
|
||||
|
||||
class PenilaiController extends Controller
|
||||
{
|
||||
public $user;
|
||||
@@ -69,19 +69,16 @@ class PenilaiController extends Controller
|
||||
public function sederhana(Request $request, $id)
|
||||
{
|
||||
|
||||
$basicData = $this->surveyorController->getCommonData();
|
||||
|
||||
$documentId = $request->query('documentId');
|
||||
$inspeksiId = $request->query('inspeksiId');
|
||||
$jaminanId = $request->query('jaminanId');
|
||||
|
||||
$permohonan = $this->surveyorController->getPermohonanJaminanId($id, $documentId, $jaminanId);
|
||||
|
||||
|
||||
$basicData = $this->surveyorController->getCommonData();
|
||||
|
||||
$inspeksi = Inspeksi::where('permohonan_id', $id)->where('dokument_id', $documentId)->first();
|
||||
$lpj = Penilai::where('permohonan_id', $id)->where('dokument_id', $documentId)->first();
|
||||
|
||||
$forminspeksi = null;
|
||||
$lpjData = null;
|
||||
if ($inspeksi) {
|
||||
$forminspeksi = json_decode($inspeksi->data_form, true);
|
||||
@@ -91,7 +88,7 @@ class PenilaiController extends Controller
|
||||
$lpjData = json_decode($lpj->lpj, true);
|
||||
}
|
||||
|
||||
return view('lpj::penilai.components.lpj-sederhana-standard', compact('permohonan', 'basicData', 'forminspeksi', 'inspeksi', 'lpjData'));
|
||||
return view('lpj::penilai.components.lpj-sederhana-standard', compact('permohonan', 'forminspeksi', 'basicData', 'inspeksi', 'lpjData'));
|
||||
}
|
||||
|
||||
public function standard(Request $request, $id)
|
||||
@@ -198,8 +195,7 @@ class PenilaiController extends Controller
|
||||
|
||||
$permohonan = $this->surveyorController->getPermohonanJaminanId($permohonanId, $documentId, $jaminanId);
|
||||
$penilai = Penilai::where('permohonan_id', $permohonanId)->where('dokument_id', $documentId)->first();
|
||||
$inspeksi = Inspeksi::where('permohonan_id', $permohonanId)->where
|
||||
('dokument_id', $documentId)->first();
|
||||
$inspeksi = Inspeksi::where('permohonan_id', $permohonanId)->where('dokument_id', $documentId)->first();
|
||||
$formFoto = null;
|
||||
if ($inspeksi) {
|
||||
$formFoto = json_decode($inspeksi->foto_form, true);
|
||||
@@ -303,18 +299,75 @@ class PenilaiController extends Controller
|
||||
|
||||
public function export_kertas_kerja(Request $request)
|
||||
{
|
||||
|
||||
$permohonanId = $request->query('permohonanId');
|
||||
$documentId = $request->query('documentId');
|
||||
$inspeksiId = $request->query('inspeksiId');
|
||||
$jaminanId = $request->query('jaminanId');
|
||||
|
||||
$data = Inspeksi::where('permohonan_id', $permohonanId)->where('dokument_id', $documentId)->first();
|
||||
// Fetch the data from the database
|
||||
$data = Inspeksi::where('permohonan_id', $permohonanId)
|
||||
->where('dokument_id', $documentId)
|
||||
->first();
|
||||
|
||||
return view('lpj::component.kertas-kerja', compact('data'));
|
||||
// return Excel::download(new KertasKerjaExport($data), 'kertas-kerja.xlsx');
|
||||
// Check if data exists
|
||||
if (!$data) {
|
||||
return response()->json(['message' => 'Data not found'], 404);
|
||||
}
|
||||
|
||||
// Decode the JSON fields
|
||||
$dataForm = json_decode($data->data_form, true);
|
||||
$fotoForm = json_decode($data->foto_form, true);
|
||||
$denahForm = json_decode($data->denah_form, true);
|
||||
$dataPembanding = json_decode($data->data_pembanding, true);
|
||||
|
||||
// Prepare the data for export
|
||||
$exportData = [
|
||||
'objek' => [
|
||||
'jenis_aset' => $dataForm['asset']['jenis_asset']['sesuai'] ?? '',
|
||||
'luas_tanah' => $dataForm['tanah']['luas_tanah']['tidak sesuai'] ?? '',
|
||||
'harga' => $dataForm['asset']['harga'] ?? '',
|
||||
'tanggal_penawaran' => $dataForm['tanggal_penawaran'] ?? '',
|
||||
'diskon' => $dataForm['diskon'] ?? '',
|
||||
'no_telepon' => $dataForm['no_telepon'] ?? '',
|
||||
'nama_nara_sumber' => $dataForm['nama_nara_sumber'] ?? '',
|
||||
'status_nara_sumber' => $dataForm['status_nara_sumber'] ?? '',
|
||||
'alamat' => $dataForm['alamat'] ?? '',
|
||||
// Add other fields as necessary
|
||||
],
|
||||
'pembanding1' => [],
|
||||
'pembanding2' => [],
|
||||
'pembanding3' => [],
|
||||
'foto_peta' => [
|
||||
'foto_tempat' => $dataForm['foto_tempat'] ?? [],
|
||||
'foto_gistaru' => $dataForm['foto_gistaru'] ?? [],
|
||||
'foto_bhumi' => $dataForm['foto_bhumi'] ?? [],
|
||||
'foto_argis_region' => $dataForm['foto_argis_region'] ?? [],
|
||||
],
|
||||
'foto_objek' => $fotoForm['object_jaminan'] ?? [],
|
||||
'foto_objek1' => [], // Populate with relevant data
|
||||
'foto_objek2' => [], // Populate with relevant data
|
||||
'tanggal_penilaian' => $data->tanggal_penilaian ?? '',
|
||||
'nama_pemilik' => $data->nama_pemilik ?? '',
|
||||
'lokasi_lengkap' => $data->lokasi_lengkap ?? '',
|
||||
];
|
||||
|
||||
// Extract data pembanding
|
||||
if (isset($dataPembanding['data_pembanding'])) {
|
||||
foreach ($dataPembanding['data_pembanding'] as $index => $pembanding) {
|
||||
if ($index == 0) {
|
||||
$exportData['pembanding1'] = $pembanding;
|
||||
} elseif ($index == 1) {
|
||||
$exportData['pembanding2'] = $pembanding;
|
||||
} elseif ($index == 2) {
|
||||
$exportData['pembanding3'] = $pembanding;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Now create the export
|
||||
// return response()->json([ 'data' => $fotoForm]);
|
||||
return Excel::download(new KertasKerjaExport($exportData), 'kertas-kerja.xlsx');
|
||||
}
|
||||
|
||||
|
||||
|
||||
public function import_kertas_kerja(Request $request)
|
||||
{
|
||||
@@ -523,4 +576,48 @@ class PenilaiController extends Controller
|
||||
}
|
||||
|
||||
|
||||
public function print_out(Request $request)
|
||||
{
|
||||
$documentId = $request->query('documentId');
|
||||
$jaminanId = $request->query('jaminanId');
|
||||
$permohonanId = $request->query('permohonanId');
|
||||
|
||||
$permohonan = $this->surveyorController->getPermohonanJaminanId($permohonanId, $documentId, $jaminanId);
|
||||
$basicData = $this->surveyorController->getCommonData();
|
||||
|
||||
$inspeksi = Inspeksi::where('permohonan_id', $permohonanId)->where('dokument_id', $documentId)->first();
|
||||
$lpj = Penilai::where('permohonan_id', $permohonanId)->where('dokument_id', $documentId)->first();
|
||||
|
||||
$forminspeksi = null;
|
||||
$lpjData = null;
|
||||
$formFoto = null;
|
||||
|
||||
if ($inspeksi) {
|
||||
$forminspeksi = json_decode($inspeksi->data_form, true);
|
||||
|
||||
$formFoto = json_decode($inspeksi->foto_form, true);
|
||||
// $denahForm = json_decode($data->denah_form, true);
|
||||
}
|
||||
|
||||
if ($lpj) {
|
||||
$lpjData = json_decode($lpj->lpj, true);
|
||||
}
|
||||
|
||||
|
||||
$pdf =Pdf::loadView('lpj::penilai.components.print-out', compact(
|
||||
'permohonan',
|
||||
'forminspeksi',
|
||||
'lpjData',
|
||||
'formFoto',
|
||||
'basicData',
|
||||
'inspeksi',
|
||||
'lpj'
|
||||
));
|
||||
|
||||
$pdf->setPaper('A4', 'portrait');
|
||||
|
||||
return $pdf->download('laporan.pdf');
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -11,6 +11,7 @@
|
||||
use Modules\Location\Models\District;
|
||||
use Modules\Location\Models\Province;
|
||||
use Modules\Location\Models\Village;
|
||||
use Modules\Lpj\Models\PermohonanPembatalan;
|
||||
use Modules\Lpj\Exports\PermohonanExport;
|
||||
use Modules\Lpj\Http\Requests\PermohonanRequest;
|
||||
use Modules\Lpj\Models\Branch;
|
||||
@@ -65,7 +66,7 @@
|
||||
$keterangan,
|
||||
[], // beforeRequest is empty for new permohonan
|
||||
$permohonan->toArray(),
|
||||
$filePath
|
||||
$filePath,
|
||||
);
|
||||
return redirect()
|
||||
->route('permohonan.index')->with('success', 'Permohonan created successfully');
|
||||
@@ -353,4 +354,38 @@
|
||||
// $pdf = Pdf::loadView('lpj::permohonan.print', compact('permohonan'));
|
||||
// return $pdf->stream();
|
||||
}
|
||||
|
||||
public function showPembatalan($id)
|
||||
{
|
||||
$permohonan = Permohonan::with(['pembatalan','debiture'])->findOrFail($id);
|
||||
return view('lpj::permohonan.pembatalan-form', compact('permohonan'));
|
||||
}
|
||||
|
||||
|
||||
public function pembatalan(Request $request)
|
||||
{
|
||||
// Validate the request
|
||||
$validatedData = $request->validate([
|
||||
'permohonan_id' => 'required|exists:permohonan,id',
|
||||
'alasan_pembatalan' => 'required|string',
|
||||
'file_pembatalan' => 'required|file|mimes:pdf,doc,docx|max:2048',
|
||||
]);
|
||||
|
||||
// Handle file upload
|
||||
if ($request->hasFile('file_pembatalan')) {
|
||||
$file = $request->file('file_pembatalan');
|
||||
$filename = time() . '_' . $file->getClientOriginalName();
|
||||
$filePath = $file->storeAs('pembatalan', $filename, 'public');
|
||||
$validatedData['file_pembatalan'] = $filePath;
|
||||
}
|
||||
|
||||
// Add created_by
|
||||
$validatedData['created_by'] = auth()->id();
|
||||
|
||||
// Create new PermohonanPembatalan
|
||||
$pembatalan = PermohonanPembatalan::create($validatedData);
|
||||
|
||||
return redirect()->route('permohonan.index')->with('success', 'Pembatalan Permohonan Menunggu Approval');
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -22,7 +22,7 @@ use Modules\Lpj\Models\PenawaranTender;
|
||||
|
||||
use Modules\Lpj\Models\Permohonan;
|
||||
use Modules\Lpj\Models\StatusPermohonan;
|
||||
use Modules\Lpj\Models\TujuanPenilaianKJPP;
|
||||
use Modules\Lpj\Models\TujuanPenilaian;
|
||||
|
||||
class ProsesPenawaranController extends Controller
|
||||
{
|
||||
@@ -961,7 +961,7 @@ class ProsesPenawaranController extends Controller
|
||||
$permohonan = Permohonan::find($id);
|
||||
// dd($permohonan);
|
||||
$status = StatusPermohonan::all();
|
||||
$tujuan_penilaian_kjpp = TujuanPenilaianKJPP::all();
|
||||
$tujuan_penilaian_kjpp = TujuanPenilaian::all();
|
||||
$jenis_laporan = JenisLaporan::all();
|
||||
$kjpp = KJPP::all();
|
||||
|
||||
|
||||
@@ -68,6 +68,7 @@ use Modules\Lpj\Models\HubunganPenghuniJaminan;
|
||||
use Modules\Lpj\Models\AnalisaUnit;
|
||||
use Modules\Lpj\Models\GolonganMasySekitar;
|
||||
use Modules\Lpj\Models\TingkatKeramaian;
|
||||
use Modules\Lpj\Models\TujuanPenilaian;
|
||||
use Modules\Lpj\Models\LaluLintasLokasi;
|
||||
use Modules\Lpj\Models\SpekBagunanAnalisaDetail;
|
||||
use Modules\Lpj\Http\Requests\SurveyorRequest;
|
||||
@@ -644,7 +645,7 @@ class SurveyorController extends Controller
|
||||
'address', 'village_code', 'district_code', 'city_code', 'province_code',
|
||||
'tahun', 'luas_tanah', 'luas_bangunan', 'tahun_bangunan',
|
||||
'status_nara_sumber', 'harga', 'harga_diskon', 'diskon', 'total', 'nama_nara_sumber',
|
||||
'peruntukan', 'penawaran_transaksi', 'nomor_tlp',
|
||||
'peruntukan', 'penawaran', 'telepon','hak_properti',
|
||||
'kordinat_lat', 'kordinat_lng', 'jenis_aset','foto_objek'
|
||||
];
|
||||
|
||||
@@ -693,8 +694,8 @@ class SurveyorController extends Controller
|
||||
$fields = [
|
||||
'address', 'village_code', 'district_code', 'city_code', 'province_code',
|
||||
'luas_tanah', 'luas_tanah_bagunan', 'total', 'diskon', 'harga_diskon',
|
||||
'status_nara_sumber', 'harga', 'nama_nara_sumber',
|
||||
'kordinat_lat', 'kordinat_lng', 'jenis_aset',
|
||||
'status_nara_sumber', 'harga', 'nama_nara_sumber','hak_properti','telepon',
|
||||
'kordinat_lat', 'kordinat_lng', 'jenis_aset','penawaran',
|
||||
];
|
||||
|
||||
$inspeksi = Inspeksi::where('permohonan_id', $request->input('permohonan_id'))
|
||||
@@ -787,9 +788,13 @@ class SurveyorController extends Controller
|
||||
}
|
||||
// Fields lainnya dalam asset
|
||||
else {
|
||||
if (!isset($dataForm['asset'][$field])) {
|
||||
$dataForm['asset'][$field] = [];
|
||||
}
|
||||
$dataForm['asset'][$field] = $newValue;
|
||||
}
|
||||
|
||||
|
||||
$needsSave = true;
|
||||
}
|
||||
}
|
||||
@@ -1526,7 +1531,13 @@ class SurveyorController extends Controller
|
||||
$filteredRecords = $query->count();
|
||||
|
||||
// Get the data for the current page
|
||||
|
||||
if ($type == 'Spek Bangunan') {
|
||||
$data = $query->with(['bangunanKategori'])->get();
|
||||
}else{
|
||||
$data = $query->get();
|
||||
}
|
||||
|
||||
|
||||
// Calculate the page count
|
||||
$pageCount = ceil($totalRecords / $request->get('size'));
|
||||
@@ -1534,6 +1545,7 @@ class SurveyorController extends Controller
|
||||
// Calculate the current page number
|
||||
$currentPage = 0 + 1;
|
||||
|
||||
|
||||
// Return the response data as a JSON object
|
||||
return response()->json([
|
||||
'draw' => $request->get('draw'),
|
||||
@@ -1663,6 +1675,7 @@ class SurveyorController extends Controller
|
||||
'hubPenghuni' => HubunganPenghuniJaminan::all(),
|
||||
'perkerasanJalan' => PerkerasanJalan::all(),
|
||||
'terletakDiArea' => TerletakArea::all(),
|
||||
'tujuanPenilaian' => TujuanPenilaian::all()
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
@@ -110,8 +110,7 @@ class FormSurveyorRequest extends FormRequest
|
||||
|
||||
'nama_bangunan.*' => 'required|string|max:255',
|
||||
'spek_kategori_bangunan.*' => 'nullable|string',
|
||||
'spek_bangunan.*.*' => 'array',
|
||||
'spek_bangunan.*.*.*' => 'string',
|
||||
'spek_bangunan.*.*.lainnya' => 'nullable|string',
|
||||
|
||||
'sarana_pelengkap' => 'required',
|
||||
'sarana_pelengkap_input' => 'nullable|array',
|
||||
|
||||
@@ -163,4 +163,8 @@
|
||||
{
|
||||
return $this->hasMany(DokumenJaminan::class);
|
||||
}
|
||||
|
||||
public function pembatalan(){
|
||||
return $this->hasMany(PermohonanPembatalan::class);
|
||||
}
|
||||
}
|
||||
|
||||
50
app/Models/PermohonanPembatalan.php
Normal file
50
app/Models/PermohonanPembatalan.php
Normal file
@@ -0,0 +1,50 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Lpj\Models;
|
||||
|
||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
use Illuminate\Database\Eloquent\SoftDeletes;
|
||||
use Modules\Lpj\Models\Permohonan;
|
||||
use Modules\Usermanagement\Models\User;
|
||||
|
||||
class PermohonanPembatalan extends Base
|
||||
{
|
||||
|
||||
protected $table = 'permohonan_pembatalan';
|
||||
|
||||
protected $fillable = [
|
||||
'permohonan_id',
|
||||
'alasan_pembatalan',
|
||||
'file_pembatalan',
|
||||
'status',
|
||||
'keterangan',
|
||||
'authorized_at',
|
||||
'authorized_status',
|
||||
'created_by',
|
||||
'updated_by',
|
||||
'deleted_by',
|
||||
'authorized_by',
|
||||
];
|
||||
|
||||
protected $dates = [
|
||||
'created_at',
|
||||
'updated_at',
|
||||
'deleted_at',
|
||||
'authorized_at',
|
||||
];
|
||||
|
||||
protected $casts = [
|
||||
'authorized_status' => 'string',
|
||||
];
|
||||
|
||||
// Relationship with Permohonan
|
||||
public function permohonan()
|
||||
{
|
||||
return $this->belongsTo(Permohonan::class, 'permohonan_id');
|
||||
}
|
||||
|
||||
public function creator(){
|
||||
return $this->belongsTo(User::class, 'created_by');
|
||||
}
|
||||
}
|
||||
@@ -20,7 +20,7 @@ class SpekBangunan extends Model
|
||||
|
||||
|
||||
public function bangunanKategori(){
|
||||
return $this->belongsTo(SpekKategoriBangunan::class, 'spek_kategori_bangunan_id');
|
||||
return $this->belongsTo(SpekKategoritBangunan::class, 'spek_kategori_bangunan_id');
|
||||
}
|
||||
|
||||
protected static function newFactory(): SpekBangunanFactory
|
||||
|
||||
@@ -0,0 +1,35 @@
|
||||
<?php
|
||||
|
||||
use Illuminate\Database\Migrations\Migration;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
|
||||
class CreatePermohonanPembatalansTable extends Migration
|
||||
{
|
||||
public function up()
|
||||
{
|
||||
Schema::create('permohonan_pembatalan', function (Blueprint $table) {
|
||||
$table->id();
|
||||
$table->unsignedBigInteger('permohonan_id');
|
||||
$table->text('alasan_pembatalan');
|
||||
$table->string('file_pembatalan');
|
||||
$table->enum('status', ['pending', 'approved', 'rejected'])->default('pending');
|
||||
$table->text('keterangan')->nullable();
|
||||
$table->timestamps();
|
||||
$table->timestamp('authorized_at')->nullable();
|
||||
$table->char('authorized_status', 1)->nullable();
|
||||
$table->softDeletes();
|
||||
$table->unsignedBigInteger('created_by')->nullable();
|
||||
$table->unsignedBigInteger('updated_by')->nullable();
|
||||
$table->unsignedBigInteger('deleted_by')->nullable();
|
||||
$table->unsignedBigInteger('authorized_by')->nullable();
|
||||
|
||||
$table->foreign('permohonan_id')->references('id')->on('permohonan')->onDelete('cascade');
|
||||
});
|
||||
}
|
||||
|
||||
public function down()
|
||||
{
|
||||
Schema::dropIfExists('permohonan_pembatalan');
|
||||
}
|
||||
}
|
||||
14
module.json
14
module.json
@@ -26,6 +26,18 @@
|
||||
"pemohon-eo"
|
||||
]
|
||||
},
|
||||
{
|
||||
"title": "Pembatalan",
|
||||
"path": "pembatalan",
|
||||
"icon": "ki-filled ki-file-deleted text-lg text-danger",
|
||||
"classes": "",
|
||||
"attributes": [],
|
||||
"permission": "",
|
||||
"roles": [
|
||||
"administrator",
|
||||
"pemohon-eo"
|
||||
]
|
||||
},
|
||||
{
|
||||
"title": "Persetujuan Penawaran",
|
||||
"path": "persetujuan-penawaran",
|
||||
@@ -179,7 +191,7 @@
|
||||
{
|
||||
"title": "Authorization",
|
||||
"path": "authorization",
|
||||
"icon": "ki-filled ki-security-user text-lg text-primary",
|
||||
"icon": "ki-filled ki-security-user text-lg text-info",
|
||||
"classes": "",
|
||||
"attributes": [],
|
||||
"permission": "",
|
||||
|
||||
@@ -1,11 +1,22 @@
|
||||
<div class="card {{ isset($hidePermohonan) ? 'hidden' : '' }}">
|
||||
<div class="card-header" id="advanced_settings_appearance">
|
||||
@php
|
||||
$title = $title ?? 'Data Permohonan';
|
||||
@endphp
|
||||
<h3 class="card-title">
|
||||
Data Permohonan
|
||||
{{ $title }}
|
||||
</h3>
|
||||
|
||||
<div class="flex items-center gap-2">
|
||||
<a href="{{ route($backLink) }}" class="btn btn-xs btn-info"><i class="ki-filled ki-exit-left"></i> Back</a>
|
||||
@if (isset($id))
|
||||
<a href="{{ route($backLink, ['id' => $id]) }}" class="btn btn-xs btn-info">
|
||||
<i class="ki-filled ki-exit-left"></i> Back
|
||||
</a>
|
||||
@else
|
||||
<a href="{{ route($backLink) }}" class="btn btn-xs btn-info">
|
||||
<i class="ki-filled ki-exit-left"></i> Back
|
||||
</a>
|
||||
@endif
|
||||
</div>
|
||||
</div>
|
||||
<div class="card-body lg:py-7.5 grid grid-cols-3">
|
||||
@@ -49,7 +60,8 @@
|
||||
<h3 class="text-md font-medium text-gray-900">
|
||||
Status Bayar:
|
||||
</h3>
|
||||
<span class="text-md font-bold {{ $permohonan->status_bayar === 'belum_bayar' ? 'text-red-600' : 'text-green-600' }} uppercase">
|
||||
<span
|
||||
class="text-md font-bold {{ $permohonan->status_bayar === 'belum_bayar' ? 'text-red-600' : 'text-green-600' }} uppercase">
|
||||
{{ str_replace('_', ' ', $permohonan->status_bayar) }}
|
||||
</span>
|
||||
</div>
|
||||
@@ -81,7 +93,7 @@
|
||||
Name
|
||||
</td>
|
||||
<td class="py-2 text-gray-800 font-normaltext-sm">
|
||||
{{ $permohonan->debiture->name ?? "" }}
|
||||
{{ $permohonan->debiture->name ?? '' }}
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
@@ -89,7 +101,7 @@
|
||||
Email
|
||||
</td>
|
||||
<td class="py-3 text-gray-700 text-2sm font-normal">
|
||||
{{ $permohonan->debiture->email ?? "" }}
|
||||
{{ $permohonan->debiture->email ?? '' }}
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
@@ -97,7 +109,7 @@
|
||||
Phone
|
||||
</td>
|
||||
<td class="py-3 text-gray-700 text-2sm font-normal">
|
||||
{{ $permohonan->debiture->phone ?? "" }}
|
||||
{{ $permohonan->debiture->phone ?? '' }}
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
@@ -106,7 +118,7 @@
|
||||
Address
|
||||
</td>
|
||||
<td class="py-3 text-gray-700 text-sm font-normal">
|
||||
{{ $permohonan->debiture->address ?? "" }}
|
||||
{{ $permohonan->debiture->address ?? '' }}
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
@@ -114,7 +126,11 @@
|
||||
|
||||
</td>
|
||||
<td class="py-3 text-gray-700 text-sm font-normal">
|
||||
{{ $permohonan->debiture->village->name ?? "" }}, {{ $permohonan->debiture->district->name ?? "" }}, {{ $permohonan->debiture->city->name ?? "" }}, {{ $permohonan->debiture->province->name ?? "" }} - {{ $permohonan->debiture->village->postal_code ?? "" }}
|
||||
{{ $permohonan->debiture->village->name ?? '' }},
|
||||
{{ $permohonan->debiture->district->name ?? '' }},
|
||||
{{ $permohonan->debiture->city->name ?? '' }},
|
||||
{{ $permohonan->debiture->province->name ?? '' }} -
|
||||
{{ $permohonan->debiture->village->postal_code ?? '' }}
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
@@ -126,7 +142,7 @@
|
||||
Cabang
|
||||
</td>
|
||||
<td class="py-2 text-gray-800 font-normaltext-sm">
|
||||
{{ $permohonan->debiture->branch->name ?? "" }}
|
||||
{{ $permohonan->debiture->branch->name ?? '' }}
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
@@ -134,7 +150,7 @@
|
||||
CIF
|
||||
</td>
|
||||
<td class="py-2 text-gray-800 font-normaltext-sm">
|
||||
{{ $permohonan->debiture->cif ?? "" }}
|
||||
{{ $permohonan->debiture->cif ?? '' }}
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
@@ -142,7 +158,7 @@
|
||||
Nomor Rekening
|
||||
</td>
|
||||
<td class="py-3 text-gray-700 text-sm font-normal">
|
||||
{{ $permohonan->debiture->nomor_rekening ?? "" }}
|
||||
{{ $permohonan->debiture->nomor_rekening ?? '' }}
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
@@ -150,7 +166,7 @@
|
||||
NPWP
|
||||
</td>
|
||||
<td class="py-3 text-gray-700 text-2sm font-normal">
|
||||
{{ $permohonan->debiture->npwp ?? "" }}
|
||||
{{ $permohonan->debiture->npwp ?? '' }}
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
@@ -167,8 +183,10 @@
|
||||
</div>
|
||||
<div data-accordion="true">
|
||||
@foreach ($permohonan->debiture->documents as $dokumen)
|
||||
<div class="accordion-item {{ count($permohonan->debiture->documents) == 1 ? 'active' : '' }} [&:not(:last-child)]:border-b border-b-gray-200" data-accordion-item="true" id="accordion_detail_jaminan">
|
||||
<button class="accordion-toggle py-4 group mx-8" data-accordion-toggle="#accordion_detail_jaminan_{{ $loop->index }}">
|
||||
<div class="accordion-item {{ count($permohonan->debiture->documents) == 1 ? 'active' : '' }} [&:not(:last-child)]:border-b border-b-gray-200"
|
||||
data-accordion-item="true" id="accordion_detail_jaminan">
|
||||
<button class="accordion-toggle py-4 group mx-8"
|
||||
data-accordion-toggle="#accordion_detail_jaminan_{{ $loop->index }}">
|
||||
<span class="text-base text-gray-900 font-medium">
|
||||
@if (count($permohonan->debiture->documents) > 1)
|
||||
Jaminan {{ $loop->index + 1 }}
|
||||
@@ -182,7 +200,8 @@
|
||||
</i>
|
||||
</button>
|
||||
|
||||
<div class="accordion-content {{ count($permohonan->debiture->documents) > 1 ? 'hidden' : '' }}" id="accordion_detail_jaminan_{{ $loop->index }}">
|
||||
<div class="accordion-content {{ count($permohonan->debiture->documents) > 1 ? 'hidden' : '' }}"
|
||||
id="accordion_detail_jaminan_{{ $loop->index }}">
|
||||
|
||||
<div class="card-body lg:py-7.5 grid grid-cols-2">
|
||||
<div class="mb-5">
|
||||
@@ -190,7 +209,7 @@
|
||||
Pemilik Jaminan:
|
||||
</h3>
|
||||
<span class="text-2sm text-gray-700">
|
||||
{{ $dokumen->pemilik->name?? "" }}
|
||||
{{ $dokumen->pemilik->name ?? '' }}
|
||||
</span>
|
||||
</div>
|
||||
<div class="mb-5">
|
||||
@@ -198,7 +217,7 @@
|
||||
Jenis Jaminan:
|
||||
</h3>
|
||||
<span class="text-2sm text-gray-700">
|
||||
{{ $dokumen->jenisJaminan->name?? "" }}
|
||||
{{ $dokumen->jenisJaminan->name ?? '' }}
|
||||
</span>
|
||||
</div>
|
||||
<div class="mb-5">
|
||||
@@ -206,7 +225,7 @@
|
||||
Hubungan Pemilik Jaminan:
|
||||
</h3>
|
||||
<span class="text-2sm text-gray-700">
|
||||
{{ $dokumen->pemilik->hubungan_pemilik->name?? "" }}
|
||||
{{ $dokumen->pemilik->hubungan_pemilik->name ?? '' }}
|
||||
</span>
|
||||
</div>
|
||||
<div class="mb-5">
|
||||
@@ -214,13 +233,18 @@
|
||||
Alamat Pemilik Jaminan:
|
||||
</h3>
|
||||
<span class="text-2sm text-gray-700">
|
||||
{{ $dokumen->pemilik->address ?? ""}},
|
||||
<br> {{ $dokumen->pemilik->village->name ?? "" }}, {{ $dokumen->pemilik->district->name ?? "" }}, {{ $dokumen->pemilik->city->name ?? "" }}, {{ $dokumen->pemilik->province->name ?? "" }} - {{ $dokumen->pemilik->village->postal_code ?? "" }}
|
||||
{{ $dokumen->pemilik->address ?? '' }},
|
||||
<br> {{ $dokumen->pemilik->village->name ?? '' }},
|
||||
{{ $dokumen->pemilik->district->name ?? '' }},
|
||||
{{ $dokumen->pemilik->city->name ?? '' }},
|
||||
{{ $dokumen->pemilik->province->name ?? '' }} -
|
||||
{{ $dokumen->pemilik->village->postal_code ?? '' }}
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="card-table scrollable-x-auto pb-3">
|
||||
<a href="{{ route('debitur.jaminan.bulk.download',['id' => $permohonan->debiture->id,'jaminan' => $dokumen->id]) }}" class="ml-6 btn btn-dark dark:btn-light">
|
||||
<a href="{{ route('debitur.jaminan.bulk.download', ['id' => $permohonan->debiture->id, 'jaminan' => $dokumen->id]) }}"
|
||||
class="ml-6 btn btn-dark dark:btn-light">
|
||||
<i class="ki-outline ki-cloud-download"></i> Download Semua Dokumen
|
||||
</a>
|
||||
<table class="table align-middle text-sm text-gray-500">
|
||||
@@ -230,7 +254,7 @@
|
||||
{{ $loop->index + 1 }}. {{ $detail->jenisLegalitasJaminan->name }}
|
||||
</td>
|
||||
<td class="py-2 text-gray-800 font-normaltext-sm">
|
||||
{{ $detail->name ?? "" }}
|
||||
{{ $detail->name ?? '' }}
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
@@ -241,14 +265,21 @@
|
||||
|
||||
@if (isset($detail->dokumen_jaminan))
|
||||
@php
|
||||
$dokumen_jaminan = is_array(json_decode($detail->dokumen_jaminan)) ? json_decode($detail->dokumen_jaminan) : [$detail->dokumen_jaminan];
|
||||
$dokumen_nomor = is_array(json_decode($detail->dokumen_nomor)) ? json_decode($detail->dokumen_nomor) : ($detail->dokumen_nomor ? [$detail->dokumen_nomor] : []);
|
||||
$dokumen_jaminan = is_array(json_decode($detail->dokumen_jaminan))
|
||||
? json_decode($detail->dokumen_jaminan)
|
||||
: [$detail->dokumen_jaminan];
|
||||
$dokumen_nomor = is_array(json_decode($detail->dokumen_nomor))
|
||||
? json_decode($detail->dokumen_nomor)
|
||||
: ($detail->dokumen_nomor
|
||||
? [$detail->dokumen_nomor]
|
||||
: []);
|
||||
@endphp
|
||||
@foreach ($dokumen_jaminan as $index => $dokumen)
|
||||
<div class="flex w-full lg:w-[30%]">
|
||||
@if (in_array(Auth::user()->roles[0]->name, ['administrator', 'pemohon-eo']))
|
||||
@if (!empty($dokumen_nomor))
|
||||
<span class="flex-1 mt-2 text-info">Nomor Dokumen : {{ $dokumen_nomor[$index] }}</span>
|
||||
<span class="flex-1 mt-2 text-info">Nomor Dokumen :
|
||||
{{ $dokumen_nomor[$index] }}</span>
|
||||
@endif
|
||||
<a href="{{ route('debitur.jaminan.download', ['id' => $permohonan->debiture->id, 'dokumen' => $detail->id, 'index' => $index]) }}"
|
||||
class="flex-none badge badge-sm badge-outline mt-2 mr-2">
|
||||
@@ -256,7 +287,10 @@
|
||||
<i class="ki-filled ki-cloud-download"></i>
|
||||
</a>
|
||||
@endif
|
||||
<span class="flex-none badge badge-sm badge-outline badge-warning mt-2" onclick="viewPDF('{{ Storage::url($dokumen_jaminan[$index]) }}')"><i class="ki-filled ki-eye mr-2"></i>Preview</span>
|
||||
<span
|
||||
class="flex-none badge badge-sm badge-outline badge-warning mt-2"
|
||||
onclick="viewPDF('{{ Storage::url($dokumen_jaminan[$index]) }}')"><i
|
||||
class="ki-filled ki-eye mr-2"></i>Preview</span>
|
||||
</div>
|
||||
<br>
|
||||
@endforeach
|
||||
@@ -269,7 +303,7 @@
|
||||
Keterangan
|
||||
</td>
|
||||
<td class="py-3 text-gray-700 text-2sm font-normal">
|
||||
{{ $detail->keterangan ?? "" }}
|
||||
{{ $detail->keterangan ?? '' }}
|
||||
</td>
|
||||
</tr>
|
||||
@endforeach
|
||||
|
||||
80
resources/views/pembatalan/form.blade.php
Normal file
80
resources/views/pembatalan/form.blade.php
Normal file
@@ -0,0 +1,80 @@
|
||||
@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">
|
||||
<div class="card pb-2.5">
|
||||
<div class="card-header">
|
||||
<h3 class="card-title">Form Pembatalan Permohonan</h3>
|
||||
<div class="flex items-center gap-2">
|
||||
<a href="{{ route('pembatalan.index') }}" class="btn btn-xs btn-info"><i class="ki-filled ki-exit-left"></i> Back</a>
|
||||
</div>
|
||||
</div>
|
||||
<div class="card-body">
|
||||
<form action="{{ route('pembatalan.update', $pembatalan) }}" method="POST" class="grid gap-5">
|
||||
@method('PUT')
|
||||
@csrf
|
||||
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||
<label class="form-label max-w-56">
|
||||
Nomor Registrasi
|
||||
</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
<input type="hidden" name="permohonan_id" value="{{ $pembatalan->permohonan->id }}">
|
||||
<input type="text" class="input" value="{{ $pembatalan->permohonan->nomor_registrasi ?? '' }}" readonly>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||
<label class="form-label max-w-56">
|
||||
Nama Debitur
|
||||
</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
<input type="text" class="input" value="{{ $pembatalan->permohonan->debiture->name ?? '' }}" readonly>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||
<label class="form-label max-w-56">
|
||||
Alasan Pembatalan
|
||||
</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
<textarea readonly class="textarea @error('alasan_pembatalan') border-danger bg-danger-light @enderror"
|
||||
name="alasan_pembatalan"
|
||||
rows="4">{{ old('alasan_pembatalan', $pembatalan->alasan_pembatalan ) }}</textarea>
|
||||
@error('alasan_pembatalan')
|
||||
<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">
|
||||
Dokumen Pendukung
|
||||
</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
@if($pembatalan->file_pembatalan)
|
||||
<div class="flex gap-2">
|
||||
<a href="{{ Storage::url($pembatalan->file_pembatalan) }}" target="_blank" class="btn btn-xs btn-info">
|
||||
<i class="ki-filled ki-eye"></i> Lihat Dokumen Pendukung
|
||||
</a>
|
||||
</div>
|
||||
@endif
|
||||
@error('file_pembatalan')
|
||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||
@enderror
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="flex justify-end">
|
||||
<button type="submit" class="btn btn-primary mr-3" name="status" value="approved">Approve</button>
|
||||
<button type="submit" class="btn btn-danger" name="status" value="rejected">Reject</button>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
@endsection
|
||||
185
resources/views/pembatalan/index.blade.php
Normal file
185
resources/views/pembatalan/index.blade.php
Normal file
@@ -0,0 +1,185 @@
|
||||
@extends('layouts.main')
|
||||
|
||||
@section('breadcrumbs')
|
||||
{{ Breadcrumbs::render('pembatalan') }}
|
||||
@endsection
|
||||
|
||||
@section('content')
|
||||
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||
<div class="card card-grid min-w-full" data-datatable="false" data-datatable-page-size="10" data-datatable-state-save="false" id="pembatalan-table" data-api-url="{{ route('pembatalan.datatables') }}">
|
||||
<div class="card-header py-5 flex-wrap">
|
||||
<h3 class="card-title">
|
||||
Daftar Pembatalan Permohonan
|
||||
</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 Pembatalan Peprmohonan" id="search" type="text" value="">
|
||||
</label>
|
||||
</div>
|
||||
<div class="flex flex-wrap gap-2.5">
|
||||
<div class="h-[24px] border border-r-gray-200"></div>
|
||||
<a class="btn btn-sm btn-light" href="#"> Export to Excel </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_registrasi">
|
||||
<span class="sort"> <span class="sort-label"> Nomor Registrasi </span>
|
||||
<span class="sort-icon"> </span> </span>
|
||||
</th>
|
||||
<th class="min-w-[150px]" data-datatable-column="nama_debitur">
|
||||
<span class="sort"> <span class="sort-label"> Nama Debitur </span>
|
||||
<span class="sort-icon"> </span> </span>
|
||||
</th>
|
||||
<th class="min-w-[150px]" data-datatable-column="cabang">
|
||||
<span class="sort"> <span class="sort-label"> Cabang </span>
|
||||
<span class="sort-icon"> </span> </span>
|
||||
</th>
|
||||
<th class="min-w-[150px]" data-datatable-column="user_pemohon">
|
||||
<span class="sort"> <span class="sort-label"> User Pemohon</span>
|
||||
<span class="sort-icon"> </span> </span>
|
||||
</th>
|
||||
<th class="min-w-[150px]" data-datatable-column="alasan_pembatalan">
|
||||
<span class="sort"> <span class="sort-label"> Alasan Pembatalan </span>
|
||||
<span class="sort-icon"> </span> </span>
|
||||
</th>
|
||||
<th class="min-w-[150px]" data-datatable-column="file_pembatalan">
|
||||
<span class="sort"> <span class="sort-label"> Dokumen Pendukung </span>
|
||||
<span class="sort-icon"> </span> </span>
|
||||
</th>
|
||||
|
||||
<th class="min-w-[150px]" data-datatable-column="status">
|
||||
<span class="sort"> <span class="sort-label"> Status </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>
|
||||
@endsection
|
||||
|
||||
@push('scripts')
|
||||
<script type="module">
|
||||
const element = document.querySelector('#pembatalan-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_registrasi: {
|
||||
title: 'Nomor Registrasi',
|
||||
render: (item, data) => {
|
||||
return `${data.permohonan.nomor_registrasi}`;
|
||||
},
|
||||
},
|
||||
nama_debitur: {
|
||||
title: 'Nama Debitur',
|
||||
render: (item, data) => {
|
||||
return `${data.permohonan.debiture.name}`;
|
||||
},
|
||||
},
|
||||
cabang: {
|
||||
title: 'Cabang',
|
||||
render: (item, data) => {
|
||||
return `${data.permohonan.branch.name}`;
|
||||
},
|
||||
},
|
||||
user_pemohon: {
|
||||
title: 'User Pemohon',
|
||||
render: (item, data) => {
|
||||
return `${data.creator.name}`;
|
||||
},
|
||||
},
|
||||
alasan_pembatalan: {
|
||||
title: 'Alasan Pembatalan'
|
||||
},
|
||||
file_pembatalan: {
|
||||
title: 'Dokumen Pendukung',
|
||||
render: (item, data) => {
|
||||
if (data.file_pembatalan) {
|
||||
return `<a href="storage/${data.file_pembatalan}" download="${data.file_pembatalan}" target="_blank" class="badge badge-sm badge-outline"> Download <i class="ki-filled ki-cloud-download"></i>
|
||||
</a>`;
|
||||
} else {
|
||||
return 'Tidak ada dokumen';
|
||||
}
|
||||
}
|
||||
},
|
||||
status: {
|
||||
title: 'Status',
|
||||
render: (item, data) => {
|
||||
if (data.status === 'pending') {
|
||||
return `<span class="badge badge-sm badge-warning flex justify-center">Pending</span>`;
|
||||
} else if (data.status === 'approved') {
|
||||
return `<span class="badge badge-sm badge-success flex justify-center">Diterima</span>`;
|
||||
} else if (data.status === 'rejected') {
|
||||
return `<span class="badge badge-sm badge-danger flex justify-center">Ditolak</span>`;
|
||||
}
|
||||
}
|
||||
},
|
||||
actions: {
|
||||
title: 'Action',
|
||||
render: (item, data) => {
|
||||
@if(auth()->user()->roles()->first()->name === "administrator" || auth()->user()->roles()->first()->name === "pemohon-eo")
|
||||
if (data.status === 'pending') {
|
||||
return `<div class="flex flex-nowrap justify-center">
|
||||
<a class="btn btn-sm btn-outline btn-warning" href="pembatalan/${data.id}/edit" title="Detail Pembatalan">
|
||||
<i class="ki-filled ki-eye"></i>
|
||||
</a>
|
||||
</div>`;
|
||||
} else {
|
||||
return '';
|
||||
}
|
||||
@else
|
||||
return '';
|
||||
@endif
|
||||
},
|
||||
}
|
||||
},
|
||||
};
|
||||
|
||||
let dataTable = new KTDataTable(element, dataTableOptions);
|
||||
// Custom search functionality
|
||||
searchInput.addEventListener('input', function () {
|
||||
const searchValue = this.value.trim();
|
||||
dataTable.search(searchValue, true);
|
||||
});
|
||||
</script>
|
||||
@endpush
|
||||
@@ -121,7 +121,6 @@
|
||||
</h3>
|
||||
</div>
|
||||
<div class="card-body grid gap-2.5 w-full">
|
||||
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||
<label class="form-label max-w-56">Jenis Asset</label>
|
||||
@php
|
||||
@@ -176,6 +175,7 @@
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="card">
|
||||
<div class="card-header">
|
||||
@@ -387,6 +387,8 @@
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
@foreach ($permohonan->debiture->documents as $dokumen)
|
||||
@if ($dokumen->jenisJaminan)
|
||||
@php
|
||||
@@ -437,8 +439,7 @@
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5 w-full">
|
||||
<label for="province" class="form-label max-w-56">Luas Tanah</label>
|
||||
<input type="text" id="luas_tanah" class="input w-full currency-format"
|
||||
name="luas_tanah"
|
||||
value="{{ old('luas_tanah', $lpjData['luas_tanah'] ?? null) }}"
|
||||
name="luas_tanah" value="{{ old('luas_tanah', $lpjData['luas_tanah'] ?? null) }}"
|
||||
oninput="calculateTotal()">
|
||||
</div>
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5 w-full">
|
||||
@@ -466,7 +467,8 @@
|
||||
<div class="flex grid-col-3 gap-2.5 w-full">
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5 w-full">
|
||||
<label for="province" class="form-label max-w-56">Luas Bangunan</label>
|
||||
<input type="text" class="input w-full currency-format" id="luas_bangunan" name="luas_bangunan"
|
||||
<input type="text" class="input w-full currency-format" id="luas_bangunan"
|
||||
name="luas_bangunan"
|
||||
value="{{ old('luas_bangunan', $lpjData['luas_bangunan'] ?? null) }}"
|
||||
oninput="calculateTotal()">
|
||||
</div>
|
||||
@@ -475,8 +477,7 @@
|
||||
<label class="input">
|
||||
<i class="">Rp
|
||||
</i>
|
||||
<input type="text" class=" w-full currency-format"
|
||||
id="nilai_bangunan_1"
|
||||
<input type="text" class=" w-full currency-format" id="nilai_bangunan_1"
|
||||
name="nilai_bangunan_1"
|
||||
value="{{ old('nilai_bangunan_1', $lpjData['nilai_bangunan_1'] ?? null) }}"
|
||||
oninput="calculateTotal()">
|
||||
@@ -486,8 +487,7 @@
|
||||
<label class="input">
|
||||
<i class="">Rp
|
||||
</i>
|
||||
<input type="text" class=" w-full currency-format"
|
||||
id="nilai_bangunan_2"
|
||||
<input type="text" class=" w-full currency-format" id="nilai_bangunan_2"
|
||||
name="nilai_bangunan_2"
|
||||
value="{{ old('nilai_bangunan_2', $lpjData['nilai_bangunan_2'] ?? null) }}">
|
||||
</label>
|
||||
@@ -497,8 +497,7 @@
|
||||
<div class="flex grid-col-3 gap-2.5 w-full">
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5 w-full">
|
||||
<label for="province" class="form-label max-w-56">Sarana Pelengkap</label>
|
||||
<input type="text" class="input w-full currency-format"
|
||||
id="sarana_pelengkap"
|
||||
<input type="text" class="input w-full currency-format" id="sarana_pelengkap"
|
||||
name="sarana_pelengkap"
|
||||
value="{{ old('sarana_pelengkap', $lpjData['sarana_pelengkap'] ?? null) }}"
|
||||
oninput="calculateTotal()">
|
||||
@@ -510,11 +509,10 @@
|
||||
<i class="">Rp
|
||||
</i>
|
||||
<input type="text" class=" w-full currency-format"
|
||||
id="nilai_sarana_pelengkap_1"
|
||||
name="nilai_sarana_pelengkap_1"
|
||||
id="nilai_sarana_pelengkap_1" name="nilai_sarana_pelengkap_1"
|
||||
value="{{ old('nilai_sarana_pelengkap_1', $lpjData['nilai_sarana_pelengkap_1'] ?? null) }}"
|
||||
oninput="calculateTotal()">
|
||||
>
|
||||
|
||||
</label>
|
||||
|
||||
</div>
|
||||
@@ -527,8 +525,7 @@
|
||||
<i class="">Rp
|
||||
</i>
|
||||
<input type="text" class="w-full currency-format"
|
||||
id="nilai_sarana_pelengkap_2"
|
||||
name="nilai_sarana_pelengkap_2"
|
||||
id="nilai_sarana_pelengkap_2" name="nilai_sarana_pelengkap_2"
|
||||
value="{{ old('nilai_sarana_pelengkap_2', $lpjData['nilai_sarana_pelengkap_2'] ?? null) }}">
|
||||
</label>
|
||||
|
||||
@@ -540,8 +537,7 @@
|
||||
<i class="">Rp
|
||||
</i>
|
||||
<input type="text" class=" w-full currency-format"
|
||||
id="total_nilai_pasar_wajar"
|
||||
name="total_nilai_pasar_wajar"
|
||||
id="total_nilai_pasar_wajar" name="total_nilai_pasar_wajar"
|
||||
value="{{ old('total_nilai_pasar_wajar', $lpjData['total_nilai_pasar_wajar'] ?? null) }}">
|
||||
</label>
|
||||
</div>
|
||||
@@ -556,9 +552,8 @@
|
||||
<div class="card-body grid gap-2.5 w-full">
|
||||
<div class="flex grid-col-3 gap-2.5 w-full">
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5 w-full">
|
||||
<input type="text"
|
||||
id="likuidasi"
|
||||
name="likuidasi" class="input w-full currency-format"
|
||||
<input type="text" id="likuidasi" name="likuidasi"
|
||||
class="input w-full currency-format"
|
||||
value="{{ old('likuidasi', $lpjData['likuidasi'] ?? null) }}"
|
||||
oninput="calculateTotal()">
|
||||
</div>
|
||||
@@ -567,8 +562,7 @@
|
||||
<label class="input">
|
||||
<i class="">Rp
|
||||
</i>
|
||||
<input type="text" class=" w-full currency-format"
|
||||
id="likuidasi_nilai_1"
|
||||
<input type="text" class=" w-full currency-format" id="likuidasi_nilai_1"
|
||||
name="likuidasi_nilai_1"
|
||||
value="{{ old('likuidasi_nilai_1', $lpjData['likuidasi_nilai_1'] ?? null) }}"
|
||||
oninput="calculateTotal()">
|
||||
@@ -607,8 +601,7 @@
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5 w-full">
|
||||
<label for="province" class="form-label">Luas Bangunan</label>
|
||||
<input type="text" class="input w-full currency-format"
|
||||
id="asuransi_luas_bangunan"
|
||||
name="asuransi_luas_bangunan"
|
||||
id="asuransi_luas_bangunan" name="asuransi_luas_bangunan"
|
||||
value="{{ old('asuransi_luas_bangunan', $lpjData['asuransi_luas_bangunan'] ?? null) }}"
|
||||
oninput="calculateTotal()">
|
||||
</div>
|
||||
@@ -617,8 +610,7 @@
|
||||
<label class="input">
|
||||
<i class="">Rp
|
||||
</i>
|
||||
<input type="text" class="input w-full currency-format"
|
||||
id="asuransi_nilai_1"
|
||||
<input type="text" class="input w-full currency-format" id="asuransi_nilai_1"
|
||||
name="asuransi_nilai_1"
|
||||
value="{{ old('asuransi_nilai_1', $lpjData['asuransi_nilai_1'] ?? null) }}"
|
||||
oninput="calculateTotal()">
|
||||
@@ -642,13 +634,12 @@
|
||||
</div>
|
||||
</div>
|
||||
<div class="flex justify-end gap-2" style="margin-right: 20px; margin-top: 20px">
|
||||
<button type="button" class="btn btn-success" id="saveButton"
|
||||
onclick="saveLpjSederhanadanStandard()">
|
||||
<button type="button" class="btn btn-success" id="saveButton" onclick="saveLpjSederhanadanStandard()">
|
||||
<span id="saveButtonText">Save</span>
|
||||
</button>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
@endsection
|
||||
|
||||
|
||||
@@ -8,70 +8,11 @@
|
||||
@section('content')
|
||||
@include('lpj::assetsku.includenya')
|
||||
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||
<div class="card">
|
||||
<div class="card-header">
|
||||
<h3 class="card-title uppercase">
|
||||
Data Jaminan
|
||||
</h3>
|
||||
<div class="flex items-center gap-2">
|
||||
<a href="{{ route('penilai.show', ['id' => $permohonan->id]) }}" 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 grid-cols-2">
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||
<label class="form-label max-w-56">Nama Debitur</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
@if (isset($permohonan->debiture))
|
||||
<p class="text-2sm text-gray-700">{{ $permohonan->debiture->name }}</p>
|
||||
@endif
|
||||
</div>
|
||||
</div>
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||
<label class="form-label max-w-56">Alamat Object</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
@foreach ($permohonan->debiture->documents as $dokumen)
|
||||
<span class="text-2sm text-gray-700">
|
||||
{{ formatAlamat($dokumen->pemilik) }}
|
||||
</span>
|
||||
@endforeach
|
||||
</div>
|
||||
</div>
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||
<label class="form-label max-w-56">Nomor Registrasi</label>
|
||||
<div class="flex flex-wrap items-base line w-full">
|
||||
<p class="text-2sm text-gray-700">{{ $permohonan->nomor_registrasi }}</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||
<label class="form-label max-w-56">Cab/Direktorat</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
@if (isset($permohonan->branch))
|
||||
<p class="text-2sm text-gray-700">{{ $permohonan->branch->name }}</p>
|
||||
@endif
|
||||
</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-base line w-full">
|
||||
<p class="text-2sm text-gray-700">{{ $permohonan->nomor_registrasi }}</p>
|
||||
</div>
|
||||
</div>
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||
<label class="form-label max-w-56">AO</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
@if (isset($permohonan->user))
|
||||
<p class="text-2sm text-gray-700">{{ $permohonan->user->name }}</p>
|
||||
@endif
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
@include('lpj::component.detail-jaminan', [
|
||||
'backLink' => 'penilai.show',
|
||||
'id' => $permohonan->id,
|
||||
'title' => 'Paparan dokument',
|
||||
])
|
||||
@include('lpj::penilai.components.foto-lampiran')
|
||||
|
||||
|
||||
@@ -79,16 +20,18 @@
|
||||
<div class="card-header uppercase">
|
||||
Kertas Kerja
|
||||
</div>
|
||||
<div class="card-body">
|
||||
|
||||
<div class="card-body flex items-center justify-between">
|
||||
@php
|
||||
$url = asset('storage/' . $penilai->kertas_kerja);
|
||||
$fileName = basename($penilai->kertas_kerja);
|
||||
@endphp
|
||||
<button type="button" class="btn btn-primary" onclick="window.open('{{ $url }}', '_blank')">
|
||||
<i class="ki-outline ki-cloud-download"></i>
|
||||
Lihat Kertas Kerja</button>
|
||||
|
||||
<iframe src="https://docs.google.com/gview?url={{$url}}&embedded=true" style="width:100%; height:500px;" frameborder="0"></iframe>
|
||||
|
||||
<p class="text-2sm text-gray-700">{{ $fileName }}</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
@endsection
|
||||
|
||||
|
||||
679
resources/views/penilai/components/print-out.blade.php
Normal file
679
resources/views/penilai/components/print-out.blade.php
Normal file
@@ -0,0 +1,679 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<meta http-equiv="X-UA-Compatible" content="ie=edge">
|
||||
<title>Laporan Penilai jaminan</title>
|
||||
<style>
|
||||
body {
|
||||
font-family: Arial, sans-serif;
|
||||
margin: 20px;
|
||||
line-height: 1.6;
|
||||
}
|
||||
|
||||
h1,
|
||||
h2,
|
||||
h3 {
|
||||
color: #333;
|
||||
}
|
||||
|
||||
.container {
|
||||
width: 90%;
|
||||
margin: 0 auto;
|
||||
|
||||
padding: 20px;
|
||||
}
|
||||
|
||||
.header {
|
||||
text-align: center;
|
||||
/* margin-bottom: 20px; */
|
||||
}
|
||||
|
||||
.checkbox {
|
||||
margin-right: 10px;
|
||||
}
|
||||
|
||||
.border1 {
|
||||
border: 1px solid #000;
|
||||
padding: 5px;
|
||||
}
|
||||
|
||||
.border {
|
||||
border: 1px solid #000;
|
||||
width: 100%;
|
||||
padding: 5px;
|
||||
}
|
||||
|
||||
.judul {
|
||||
display: flex !important;
|
||||
text-align: center !important;
|
||||
gap: 5px;
|
||||
}
|
||||
|
||||
.checkbox-list {
|
||||
list-style: none;
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
.checkbox-list li {
|
||||
margin-bottom: 5px;
|
||||
}
|
||||
|
||||
.checkbox-list input[type="checkbox"] {
|
||||
margin-right: 5px;
|
||||
}
|
||||
|
||||
dl {
|
||||
display: grid;
|
||||
grid-template-columns: auto 1fr;
|
||||
gap: 5px;
|
||||
}
|
||||
|
||||
dd::before {
|
||||
content: ":";
|
||||
margin-right: 5px;
|
||||
}
|
||||
|
||||
.grid-container {
|
||||
display: grid;
|
||||
grid-template-columns: repeat(3, 1fr);
|
||||
gap: 10px;
|
||||
list-style: none;
|
||||
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.grid-container li {
|
||||
margin-bottom: 5px;
|
||||
|
||||
}
|
||||
|
||||
.grid-container label {
|
||||
vertical-align: middle;
|
||||
margin-left: 5px;
|
||||
}
|
||||
|
||||
* {
|
||||
font-size: 12px;
|
||||
}
|
||||
|
||||
h6 {
|
||||
font-size: 1em;
|
||||
}
|
||||
|
||||
.custom-dl {
|
||||
display: grid;
|
||||
grid-template-columns: 150px 1fr;
|
||||
gap: 10px;
|
||||
|
||||
}
|
||||
|
||||
.custom-dl dt::after {
|
||||
margin-left: 5px;
|
||||
}
|
||||
|
||||
.custom-dl-tujuan {
|
||||
display: grid;
|
||||
grid-template-columns: repeat(2, 1fr);
|
||||
gap: 10px;
|
||||
}
|
||||
|
||||
.photo-item {
|
||||
margin-bottom: 20px;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
}
|
||||
|
||||
.photo-image {
|
||||
max-width: 40%;
|
||||
height: auto;
|
||||
display: block;
|
||||
margin: 0 auto;
|
||||
}
|
||||
|
||||
|
||||
</style>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div class="container">
|
||||
<div class="header">
|
||||
<h6>LAPORAN PENILAIAN ATAS TANAH DAN/ATAU BANGUNAN</h6>
|
||||
<p>NO: </p>
|
||||
</div>
|
||||
|
||||
<div class="section">
|
||||
<div class="judul">
|
||||
<h6 class="border1">
|
||||
A
|
||||
</h6>
|
||||
<h6 class="border">
|
||||
TUJUAN PENILAIAN
|
||||
</h6>
|
||||
</div>
|
||||
<ul class="checkbox-list custom-dl-tujuan">
|
||||
<li>
|
||||
<dl class="n">
|
||||
<dt>Permintaan (A/O)</dt>
|
||||
<dd>ACHMAD DENI DARURI
|
||||
</dd>
|
||||
<dt>Jenis Fasilitas</dt>
|
||||
<dd>Bambu Apus</dd>
|
||||
</dl>
|
||||
</li>
|
||||
<li>
|
||||
<dl class="n">
|
||||
|
||||
<dt>Tanggal</dt>
|
||||
<dd>Bambu Apus</dd>
|
||||
<dt>Kunjungan Tanggal</dt>
|
||||
<dd>Bambu Apus</dd>
|
||||
|
||||
</dl>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
|
||||
@if (isset($basicData['tujuanPenilaian']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['tujuanPenilaian'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
<div class="section">
|
||||
<div class="judul">
|
||||
<h6 class="border1">
|
||||
B
|
||||
</h6>
|
||||
<h6 class="border">
|
||||
IDENTITAS DEBITUR
|
||||
</h6>
|
||||
</div>
|
||||
<dl class="custom-dl">
|
||||
<dt>Nama Debitur</dt>
|
||||
<dd>ACHMAD DENI DARURI
|
||||
</dd>
|
||||
<dt>Alamat dan Telepon</dt>
|
||||
<dd>Bambu Apus</dd>
|
||||
<dt>Saat menilai, penilai didampingi oleh</dt>
|
||||
<dd>
|
||||
<dl>
|
||||
<dt>Debitur / Wakil Debitur</dt>
|
||||
<dd>ACHMAD DENI DARURI
|
||||
</dd>
|
||||
<dt>Pihak Bank selain PJ</dt>
|
||||
<dd>Bambu Apus</dd>
|
||||
</dl>
|
||||
</dd>
|
||||
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
<div class="section">
|
||||
<div class="judul">
|
||||
<h6 class="border1">
|
||||
C
|
||||
</h6>
|
||||
<h6 class="border">
|
||||
JENIS JAMINAN
|
||||
</h6>
|
||||
</div>
|
||||
@if (isset($basicData['jenisJaminan']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['jenisJaminan'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</div>
|
||||
|
||||
|
||||
<div class="section">
|
||||
<div class="judul">
|
||||
<h6 class="border1">
|
||||
D
|
||||
</h6>
|
||||
<h6 class="border">
|
||||
LOKASI JAMINAN
|
||||
</h6>
|
||||
</div>
|
||||
<dl class="custom-dl">
|
||||
<dt>Terletak di</dt>
|
||||
<dd>Perumahan Villa Pamulang Mas, Jalan Palem Mas III Blok C3/5</dd>
|
||||
<dt>Kelurahan</dt>
|
||||
<dd>Bambu Apus</dd>
|
||||
<dt>Kecamatan</dt>
|
||||
<dd>Pamulang</dd>
|
||||
<dt>Kotamadya</dt>
|
||||
<dd>Tangerang Selatan</dd>
|
||||
<dt>Propinsi</dt>
|
||||
<dd>Banten</dd>
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
<div class="section">
|
||||
<div class="judul">
|
||||
<h6 class="border1">
|
||||
E
|
||||
</h6>
|
||||
<h6 class="border">
|
||||
STATUS KEPEMILIKAN, HUBUNGAN DAN PENGHUNI
|
||||
</h6>
|
||||
</div>
|
||||
<dl class="custom-dl">
|
||||
<dt>SHM No/Kelurahan/Desa </dt>
|
||||
<dd>Perumahan Villa Pamulang Mas, Jalan Palem Mas III Blok C3/5</dd>
|
||||
<dt>Tanggal</dt>
|
||||
<dd>Bambu Apus</dd>
|
||||
<dt>Atas Nama </dt>
|
||||
<dd>Pamulang</dd>
|
||||
<dt>Gambar Situasi No/Tanggal</dt>
|
||||
<dd>Tangerang Selatan</dd>
|
||||
<dt>Luas Tanah /m2</dt>
|
||||
<dd>Banten</dd>
|
||||
<dt>IMB No/Tanggal</dt>
|
||||
<dd>Banten</dd>
|
||||
<dt>Hubungan Pemilik Jaminan dengan
|
||||
Debitur</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['hubCadeb']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['hubCadeb'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
<dt>Hubungan Penghuni Jaminan dengan
|
||||
Debitur</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['hubPenghuni']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['hubPenghuni'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
<div class="section">
|
||||
<div class="judul">
|
||||
<h6 class="border1">
|
||||
F
|
||||
</h6>
|
||||
<h6 class="border">
|
||||
ANALISA TANAH DAN BANGUNAN
|
||||
</h6>
|
||||
</div>
|
||||
<dl class="custom-dl">
|
||||
<dt>Luas Tanah</dt>
|
||||
<dd>13</dd>
|
||||
<dt>Bentuk Tanah</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['bentukTanah']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['bentukTanah'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
<dt>Kontur Tanah</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['konturTanah']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['konturTanah'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
<dt>Permukaan dengan Jalan</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['konturTanah']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['konturTanah'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
<dt>Peruntukan Tanah</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['konturTanah']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['konturTanah'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
<dt>Fisik Tanah</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['konturTanah']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['konturTanah'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
<dt>Jenis Bangunan</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['jenisBangunan']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['jenisBangunan'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
<dt>Kondisi Bangunan</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['kondisiBangunan']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['kondisiBangunan'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
<dt>Sifat Bangunan</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['sifatBangunan']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['sifatBangunan'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
@foreach ($basicData['spekKategoriBangunan'] as $kategori)
|
||||
<dt>{{ $kategori->name }}</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['sifatBangunan']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['sifatBangunan'] as $sifat)
|
||||
<li><input type="checkbox">{{ $sifat->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
@endforeach
|
||||
|
||||
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
|
||||
<div class="section">
|
||||
<div class="judul">
|
||||
<h6 class="border1">
|
||||
G
|
||||
</h6>
|
||||
<h6 class="border">
|
||||
SARANA PELENGKAP DAN LINGKUNGAN
|
||||
|
||||
</h6>
|
||||
</div>
|
||||
<dl class="custom-dl">
|
||||
<dt>Luas Tanah</dt>
|
||||
<dd>13</dd>
|
||||
<dt>Lapisan perkerasan jalan dari</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['perkerasanJalan']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['perkerasanJalan'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
<dt>Lalulintas didepan lokasi</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['laluLintasLokasi']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['laluLintasLokasi'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
<dt>Golongan Masyarakat sekitar</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['golMasySekitar']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['golMasySekitar'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
<dt>Terletak didaerah</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['terletakDiArea']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['terletakDiArea'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
<dt>Disekitar lokasi</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['konturTanah']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['konturTanah'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
<dt>Dengan kondisi</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['jenisBangunan']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['jenisBangunan'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
<dt>Sifat Bangunan sekitar</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['sifatBangunan']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['sifatBangunan'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
<dt>Merupakan daerah</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['merupakanDaerah']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['merupakanDaerah'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
<dt>Fasilitas umum dekat lokasi</dt>
|
||||
<dd>
|
||||
@if (isset($basicData['fasilitasObjek']))
|
||||
<ul class="checkbox-list grid-container">
|
||||
@foreach ($basicData['fasilitasObjek'] as $item)
|
||||
<li><input type="checkbox">{{ $item->name }}</li>
|
||||
@endforeach
|
||||
</ul>
|
||||
@endif
|
||||
</dd>
|
||||
|
||||
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
|
||||
<div class="section">
|
||||
<div class="judul">
|
||||
<h6 class="border1">
|
||||
H
|
||||
</h6>
|
||||
<h6 class="border">
|
||||
ASURANSI
|
||||
|
||||
</h6>
|
||||
</div>
|
||||
<ul class="checkbox-list grid-container">
|
||||
<li><input type="checkbox" checked>Tidak Ada</li>
|
||||
<li><input type="checkbox">Ada</li>
|
||||
</ul>
|
||||
</div>
|
||||
|
||||
<div class="section">
|
||||
<div class="judul">
|
||||
<h6 class="border1">
|
||||
I
|
||||
</h6>
|
||||
<h6 class="border">
|
||||
KESIMPULAN DAN SARAN PENILAI, INFORMASI HARGA,
|
||||
TOTAL NILAI JAMINAN DAN CATATAN PERLU DIPERHATIKAN
|
||||
</h6>
|
||||
</div>
|
||||
<ul class="checkbox-list grid-container">
|
||||
<li><input type="checkbox" checked> Permohonan Baru</li>
|
||||
<li><input type="checkbox"> Penilaian Ulang Jaminan / Review Tahunan</li>
|
||||
<li><input type="checkbox"> Penambahan Fasilitas / Jaminan</li>
|
||||
<li><input type="checkbox"> Penukaran Jaminan</li>
|
||||
<li><input type="checkbox"> KPR eks BPPN</li>
|
||||
<li><input type="checkbox"> Lelang</li>
|
||||
</ul>
|
||||
</div>
|
||||
|
||||
<div class="section">
|
||||
<div class="judul">
|
||||
<h6 class="border">
|
||||
PETA LOKASI
|
||||
</h6>
|
||||
</div>
|
||||
@php
|
||||
$fotoTypes = ['foto_gistaru', 'foto_bhumi', 'foto_argis_region', 'foto_tempat'];
|
||||
@endphp
|
||||
<div class="">
|
||||
@if (isset($forminspeksi))
|
||||
@forelse ($fotoTypes as $type)
|
||||
<div class="border photo-item">
|
||||
@php
|
||||
$imagePath = $forminspeksi[$type];
|
||||
@endphp
|
||||
|
||||
<img src="{{ asset('storage/' . $imagePath) }}" alt="{{ $type }}"
|
||||
class="photo-image" onerror="this.src='{{ asset('default-image.png') }}'">
|
||||
<p class="mt-2 text-sm">{{ Str::title(str_replace('_', ' ', $type)) }}</p>
|
||||
|
||||
</div>
|
||||
@empty
|
||||
<p>Tidak ada tipe foto yang tersedia</p>
|
||||
@endforelse
|
||||
@endif
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="section">
|
||||
<div class="judul">
|
||||
<h6 class="border">
|
||||
FOTO JAMINAN
|
||||
</h6>
|
||||
</div>
|
||||
<div>
|
||||
@if (isset($formFoto))
|
||||
@foreach ($formFoto['rute_menuju_lokasi'] as $item)
|
||||
<div class="border photo-item">
|
||||
<h2 class="text-gray-600 font-semibold text-xl">
|
||||
{{ $item['name_rute'] . ' ' . $loop->index + 1 }}
|
||||
</h2>
|
||||
|
||||
<img src="{{ asset('storage/' . $item['foto_rute']) }}" alt="{{ $item['foto_rute'] }}"
|
||||
class="photo-image" onerror="this.src='{{ asset('default-image.png') }}'">
|
||||
</div>
|
||||
@endforeach
|
||||
@endif
|
||||
|
||||
@if (isset($formFoto['object_jaminan']))
|
||||
@foreach ($formFoto['object_jaminan'] as $item)
|
||||
<div class="border photo-item">
|
||||
<h2 class="text-gray-600 font-semibold text-xl">
|
||||
{{ $item['name_objek'] }}
|
||||
</h2>
|
||||
|
||||
<img src="{{ asset('storage/' . $item['foto_objek']) }}" alt="{{ $item['foto_objek'] }}"
|
||||
class="photo-image">
|
||||
</div>
|
||||
@endforeach
|
||||
@endif
|
||||
|
||||
@if (isset($formFoto['foto_basement']))
|
||||
<div class="border photo-item">
|
||||
<h2 class="text-gray-600 font-semibold text-xl">
|
||||
Basement
|
||||
</h2>
|
||||
|
||||
<img src="{{ asset('storage/' . $formFoto['foto_basement']) }}"
|
||||
alt="{{ $formFoto['foto_basement'] }}" class="photo-image">
|
||||
</div>
|
||||
@endif
|
||||
|
||||
@if (isset($formFoto['foto_gerbang']))
|
||||
<div class="border photo-item">
|
||||
<h2 class="text-gray-600 font-semibold text-xl">
|
||||
Gerbang
|
||||
</h2>
|
||||
|
||||
<img src="{{ asset('storage/' . $formFoto['foto_gerbang']) }}"
|
||||
alt="{{ $formFoto['foto_gerbang'] }}" class="photo-image">
|
||||
</div>
|
||||
@endif
|
||||
@if (isset($formFoto['pendamping']))
|
||||
<div class="border photo-item">
|
||||
<h2 class="text-gray-600 font-semibold text-xl">
|
||||
Pendamping
|
||||
</h2>
|
||||
|
||||
<img src="{{ asset('storage/' . $formFoto['pendamping']) }}"
|
||||
alt="{{ $formFoto['pendamping'] }}" class="photo-image">
|
||||
</div>
|
||||
@endif
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</body>
|
||||
|
||||
</html>
|
||||
@@ -6,114 +6,7 @@
|
||||
|
||||
@section('content')
|
||||
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||
<div class="card pb-2.5">
|
||||
<div class="card-header" id="basic_settings">
|
||||
<h3 class="card-title">
|
||||
Lampiran foto dan dokument
|
||||
</h3>
|
||||
<div class="flex items-center gap-2">
|
||||
<a href="{{ route('penilai.show', $permohonan->id) }}" 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">
|
||||
@if (isset($permohonan))
|
||||
<div data-accordion="true">
|
||||
@foreach ($permohonan->debiture->documents as $dokumen)
|
||||
<div class="accordion-item [&:not(:last-child)]:border-b border-b-gray-200"
|
||||
data-accordion-item="true" id="accordion_detail_jaminan">
|
||||
<button class="accordion-toggle py-4 group "
|
||||
data-accordion-toggle="#accordion_detail_jaminan_{{ $loop->index }}">
|
||||
<span class="text-base text-gray-900 font-medium">
|
||||
Dokument
|
||||
</span>
|
||||
<i class="ki-outline ki-plus text-gray-600 text-2sm accordion-active:hidden block">
|
||||
</i>
|
||||
<i class="ki-outline ki-minus text-gray-600 text-2sm accordion-active:block hidden">
|
||||
</i>
|
||||
</button>
|
||||
|
||||
<div class="accordion-content hidden" id="accordion_detail_jaminan_{{ $loop->index }}">
|
||||
<div class="card-table scrollable-x-auto pb-3">
|
||||
<a href="{{ route('debitur.jaminan.bulk.download', ['id' => $permohonan->debiture->id, 'jaminan' => $dokumen->id]) }}"
|
||||
class="ml-6 btn btn-dark dark:btn-light">
|
||||
<i class="ki-outline ki-cloud-download"></i> Download Semua Dokumen
|
||||
</a>
|
||||
<table class="table align-middle text-sm text-gray-500">
|
||||
@foreach ($dokumen->detail as $detail)
|
||||
<tr>
|
||||
<td class="py-2 text-gray-600 font-normal max-w-[100px]">
|
||||
{{ $loop->index + 1 }}. {{ $detail->jenisLegalitasJaminan->name }}
|
||||
</td>
|
||||
<td class="py-2 text-gray-800 font-normaltext-sm">
|
||||
{{ $detail->name ?? '' }}
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td class="py-3 max-w-[100px] align-top">
|
||||
Dokumen Jaminan
|
||||
</td>
|
||||
<td class="py-3 text-gray-700 text-2sm font-normal">
|
||||
|
||||
@if (isset($detail->dokumen_jaminan))
|
||||
@php
|
||||
$dokumen_jaminan = is_array(
|
||||
json_decode($detail->dokumen_jaminan),
|
||||
)
|
||||
? json_decode($detail->dokumen_jaminan)
|
||||
: [$detail->dokumen_jaminan];
|
||||
$dokumen_nomor = is_array(
|
||||
json_decode($detail->dokumen_nomor),
|
||||
)
|
||||
? json_decode($detail->dokumen_nomor)
|
||||
: ($detail->dokumen_nomor
|
||||
? [$detail->dokumen_nomor]
|
||||
: []);
|
||||
@endphp
|
||||
@foreach ($dokumen_jaminan as $index => $dokumen)
|
||||
<div class="flex w-full lg:w-[30%]">
|
||||
@if (in_array(Auth::user()->roles[0]->name, ['administrator', 'pemohon-eo']))
|
||||
@if (!empty($dokumen_nomor))
|
||||
<span class="flex-1 mt-2 text-info">Nomor
|
||||
Dokumen :
|
||||
{{ $dokumen_nomor[$index] }}</span>
|
||||
@endif
|
||||
<a href="{{ route('debitur.jaminan.download', ['id' => $permohonan->debiture->id, 'dokumen' => $detail->id, 'index' => $index]) }}"
|
||||
class="flex-none badge badge-sm badge-outline mt-2 mr-2">
|
||||
{{ basename($dokumen) }}
|
||||
<i class="ki-filled ki-cloud-download"></i>
|
||||
</a>
|
||||
@endif
|
||||
<span
|
||||
class="flex-none badge badge-sm badge-outline badge-warning mt-2"
|
||||
onclick="viewPDF('{{ Storage::url($dokumen_jaminan[$index]) }}')"><i
|
||||
class="ki-filled ki-eye mr-2"></i>Preview</span>
|
||||
</div>
|
||||
<br>
|
||||
@endforeach
|
||||
@endif
|
||||
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td class="py-3 max-w-[100px]">
|
||||
Keterangan
|
||||
</td>
|
||||
<td class="py-3 text-gray-700 text-2sm font-normal">
|
||||
{{ $detail->keterangan ?? '' }}
|
||||
</td>
|
||||
</tr>
|
||||
@endforeach
|
||||
</table>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
@endforeach
|
||||
</div>
|
||||
@endif
|
||||
</div>
|
||||
</div>
|
||||
@include('lpj::component.detail-jaminan', ['backLink' => 'penilai.show', 'id' => $permohonan->id, 'title' => 'Lampiran foto dan dokument'])
|
||||
@include('lpj::penilai.components.foto-lampiran')
|
||||
</div>
|
||||
@endsection
|
||||
|
||||
@@ -258,7 +258,7 @@
|
||||
</div>
|
||||
|
||||
<div class="flex justify-end gap-5">
|
||||
<a class="btn btn-success" href="#">
|
||||
<a class="btn btn-success" href="{{ route('penilai.print-out') }}?permohonanId={{ $permohonan->id }}&documentId={{ $dokumen->id }}&inspeksiId={{ $inspeksiId }}&jaminanId={{ $dokumen->jenis_jaminan_id }}">
|
||||
PRINT OUT
|
||||
</a>
|
||||
</div>
|
||||
|
||||
@@ -59,7 +59,7 @@
|
||||
<span class="sort"> <span class="sort-label"> Tujuan Penilaian </span>
|
||||
<span class="sort-icon"> </span> </span>
|
||||
</th>
|
||||
<th class="min-w-[150px]" data-datatable-column="status">
|
||||
<th class="min-w-[150px] text-center" data-datatable-column="status">
|
||||
<span class="sort"> <span class="sort-label"> Status </span>
|
||||
<span class="sort-icon"> </span> </span>
|
||||
</th>
|
||||
@@ -67,7 +67,7 @@
|
||||
<span class="sort"> <span class="sort-label"> Keterangan </span>
|
||||
<span class="sort-icon"> </span> </span>
|
||||
</th>
|
||||
<th class="min-w-[50px] text-center" data-datatable-column="actions">Action</th>
|
||||
<th class="min-w-[50px] text-right" data-datatable-column="actions">Action</th>
|
||||
</tr>
|
||||
</thead>
|
||||
</table>
|
||||
@@ -91,15 +91,15 @@
|
||||
|
||||
@push('scripts')
|
||||
<script type="text/javascript">
|
||||
function deleteData(data) {
|
||||
function deleteData(data, noReg, debitur) {
|
||||
Swal.fire({
|
||||
title: 'Are you sure?',
|
||||
text: "You won't be able to revert this!",
|
||||
title: 'Pembatalan Permohonan',
|
||||
text: "Yakin akan membatalkan permohonan dengan nomor " + noReg + " untuk Debitur " + debitur + "?",
|
||||
icon: 'warning',
|
||||
showCancelButton: true,
|
||||
confirmButtonColor: '#3085d6',
|
||||
cancelButtonColor: '#d33',
|
||||
confirmButtonText: 'Yes, delete it!'
|
||||
confirmButtonText: 'Yes!'
|
||||
}).then((result) => {
|
||||
if (result.isConfirmed) {
|
||||
$.ajaxSetup({
|
||||
@@ -108,16 +108,7 @@
|
||||
}
|
||||
});
|
||||
|
||||
$.ajax(`permohonan/${data}`, {
|
||||
type: 'DELETE'
|
||||
}).then((response) => {
|
||||
swal.fire('Deleted!', 'User has been deleted.', 'success').then(() => {
|
||||
window.location.reload();
|
||||
});
|
||||
}).catch((error) => {
|
||||
console.error('Error:', error);
|
||||
Swal.fire('Error!', 'An error occurred while deleting the file.', 'error');
|
||||
});
|
||||
window.location = `permohonan/${data}/pembatalan`;
|
||||
}
|
||||
})
|
||||
}
|
||||
@@ -166,7 +157,7 @@
|
||||
title: 'Debitur',
|
||||
render: (item, data) => {
|
||||
if (data.debiture) {
|
||||
return `${data.debiture.name}`;
|
||||
return `${data.debiture.name.toUpperCase()}`;
|
||||
}
|
||||
return "-";
|
||||
},
|
||||
@@ -195,7 +186,10 @@
|
||||
},
|
||||
},
|
||||
status: {
|
||||
title: 'Status'
|
||||
title: 'Status',
|
||||
render: (item, data) => {
|
||||
return `<span class="badge badge-sm badge-default uppercase flex justify-center">${data.status}</span>`;
|
||||
}
|
||||
},
|
||||
keterangan: {
|
||||
title: 'Keterangan'
|
||||
@@ -203,7 +197,7 @@
|
||||
actions: {
|
||||
title: 'Actions',
|
||||
render: (item, data) => {
|
||||
let actionHtml = `<div class="flex flex-nowrap justify-center gap-1.5">`;
|
||||
let actionHtml = `<div class="flex flex-nowrap justify-end gap-1.5">`;
|
||||
|
||||
if (data && data.penilaian && data.penilaian.waktu_penilaian !== null && data.status !==
|
||||
'done' && data.penilaian.authorized_status == null) {
|
||||
@@ -225,11 +219,14 @@
|
||||
actionHtml += `
|
||||
<a class="btn btn-sm btn-outline btn-info" href="permohonan/${data.id}/edit" title="Edit Permohonan">
|
||||
<i class="ki-outline ki-notepad-edit"></i>
|
||||
</a>
|
||||
<a onclick="deleteData(${data.id})" class="delete btn btn-sm btn-outline btn-danger" title="Hapus Permohonan">
|
||||
<i class="ki-outline ki-trash"></i>
|
||||
</a>
|
||||
</div>`;
|
||||
</a>`;
|
||||
if(data.status !== 'batal') {
|
||||
actionHtml += `
|
||||
<a onclick="deleteData(${data.id}, '${data.nomor_registrasi}','${data.debiture.name}')" class="delete btn btn-sm btn-outline btn-danger" title="Batalkan Permohonan">
|
||||
<i class="ki-outline ki-cross-square"></i>
|
||||
</a>`;
|
||||
}
|
||||
actionHtml += `</div>`;
|
||||
|
||||
return actionHtml;
|
||||
},
|
||||
|
||||
73
resources/views/permohonan/pembatalan-form.blade.php
Normal file
73
resources/views/permohonan/pembatalan-form.blade.php
Normal file
@@ -0,0 +1,73 @@
|
||||
@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">
|
||||
<div class="card pb-2.5">
|
||||
<div class="card-header">
|
||||
<h3 class="card-title">Form Pembatalan Permohonan</h3>
|
||||
<div class="flex items-center gap-2">
|
||||
<a href="{{ route('permohonan.index') }}" class="btn btn-xs btn-info"><i class="ki-filled ki-exit-left"></i> Back</a>
|
||||
</div>
|
||||
</div>
|
||||
<div class="card-body">
|
||||
<form action="{{ route('permohonan.pembatalan', $permohonan) }}" method="POST" class="grid gap-5" enctype="multipart/form-data">
|
||||
@csrf
|
||||
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||
<label class="form-label max-w-56">
|
||||
Nomor Registrasi
|
||||
</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
<input type="hidden" name="permohonan_id" value="{{ $permohonan->id }}">
|
||||
<input type="text" class="input" value="{{ $permohonan->nomor_registrasi ?? '' }}" readonly>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||
<label class="form-label max-w-56">
|
||||
Nama Debitur
|
||||
</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
<input type="text" class="input" value="{{ $permohonan->debiture->name ?? '' }}" readonly>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||
<label class="form-label max-w-56">
|
||||
Alasan Pembatalan
|
||||
</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
<textarea class="textarea @error('alasan_pembatalan') border-danger bg-danger-light @enderror"
|
||||
name="alasan_pembatalan"
|
||||
rows="4">{{ old('alasan_pembatalan') }}</textarea>
|
||||
@error('alasan_pembatalan')
|
||||
<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">
|
||||
Dokumen Pendukung
|
||||
</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
<input type="file" class="file-input @error('file_pembatalan') border-danger bg-danger-light @enderror"
|
||||
name="file_pembatalan">
|
||||
@error('file_pembatalan')
|
||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||
@enderror
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="flex justify-end">
|
||||
<button type="submit" class="btn btn-primary">Submit Pembatalan</button>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
@endsection
|
||||
@@ -25,7 +25,7 @@
|
||||
<input type="hidden" name="biaya_final" value="{{ $permohonan->penawaran->detail->biaya_penawaran ?? old('biaya_final') }}">
|
||||
|
||||
|
||||
<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 hidden">
|
||||
<label class="form-label max-w-56">
|
||||
Status Bayar
|
||||
</label>
|
||||
|
||||
@@ -78,7 +78,7 @@
|
||||
@if (isset($kjpp))
|
||||
<option value="{{ $row->id }}"
|
||||
{{ in_array($row->id, old('kjpp', [])) ? 'selected' : '' }}>
|
||||
{{ $row->name }}
|
||||
{{ $row->name }} || {{ $row->jenis_kantor }}
|
||||
</option>
|
||||
@endif
|
||||
@endforeach
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
<div class="card w-full bg-white rounded-lg shadow-md overflow-hidden">
|
||||
<div class="card w-full rounded-lg shadow-md overflow-hidden">
|
||||
<div class="card-header">
|
||||
<h3 class="card-title uppercase">
|
||||
Analisa Bangunan
|
||||
@@ -78,7 +78,8 @@
|
||||
(isset($forminspeksi['bangunan']['jenis_bangunan']) &&
|
||||
(is_array($forminspeksi['bangunan']['jenis_bangunan']) &&
|
||||
in_array($item->name, $forminspeksi['bangunan']['jenis_bangunan'])))
|
||||
? 'checked' : '' }}
|
||||
? 'checked'
|
||||
: '' }}
|
||||
onclick="toggleCheckboxVisibility('jenis_bangunan', 'jenis_bangunan_lainnya', ['lainnya'])" />
|
||||
{{ $item->name }}
|
||||
</label>
|
||||
@@ -169,17 +170,14 @@
|
||||
@if (@isset($basicData['spekKategoriBangunan']))
|
||||
@foreach ($basicData['spekKategoriBangunan'] as $item)
|
||||
<div>
|
||||
<input type="hidden" name="spek_kategori_bangunan[]"
|
||||
value="{{ $item->name }}">
|
||||
<input type="hidden" name="spek_kategori_bangunan[]" value="{{ $item->name }}">
|
||||
<label
|
||||
class="form-label flex items-center gap-3 text-nowrap">{{ $item->name }}</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
<div class="flex flex-col items-start gap-4"
|
||||
style="margin-top: 10px">
|
||||
<div class="flex flex-col items-start gap-4" style="margin-top: 10px">
|
||||
@foreach ($basicData['spekBangunan'] as $spek)
|
||||
@if ($spek->spek_kategori_bangunan_id == $item->id)
|
||||
<label
|
||||
class="form-label flex items-center gap-2.5">
|
||||
<label class="form-label flex items-center gap-2.5">
|
||||
<input class="checkbox"
|
||||
name="spek_bangunan[{{ $index }}][{{ $item->name }}][]"
|
||||
type="checkbox"
|
||||
@@ -192,17 +190,20 @@
|
||||
</label>
|
||||
@endif
|
||||
@endforeach
|
||||
<label class="form-label flex items-center gap-2.5 mt-2">
|
||||
<input class="input" type="text"
|
||||
name="spek_bangunan[{{ $index }}][{{ $item->name }}][lainnya]"
|
||||
placeholder="Lainnya (sebutkan)"
|
||||
value="{{ isset($bangunan['spek_kategori_bangunan'][$item->name]['lainnya']) ? $bangunan['spek_kategori_bangunan'][$item->name]['lainnya'] : '' }}">
|
||||
</label>
|
||||
</div>
|
||||
<em id="error-spek_bangunan_{{ $item->name }}"
|
||||
class="alert text-danger text-sm"></em>
|
||||
<em id="error-spek_bangunan_{{ $item->name }}" class="alert text-danger text-sm"></em>
|
||||
</div>
|
||||
</div>
|
||||
@endforeach
|
||||
@endif
|
||||
</div>
|
||||
<button type="button"
|
||||
class="mt-2 btn btn-danger btn-outline btn-xs delete-button"
|
||||
style="display: none;">Hapus</button>
|
||||
<button type="button" class="mt-2 btn btn-danger btn-outline btn-xs delete-button" style="display: none;">Hapus</button>
|
||||
</div>
|
||||
@endforeach
|
||||
@else
|
||||
@@ -213,13 +214,10 @@
|
||||
@if (@isset($basicData['spekKategoriBangunan']))
|
||||
@foreach ($basicData['spekKategoriBangunan'] as $item)
|
||||
<div>
|
||||
<input type="hidden" name="spek_kategori_bangunan[]"
|
||||
value="{{ $item->name }}">
|
||||
<label
|
||||
class="form-label flex items-center gap-3 text-nowrap">{{ $item->name }}</label>
|
||||
<input type="hidden" name="spek_kategori_bangunan[]" value="{{ $item->name }}">
|
||||
<label class="form-label flex items-center gap-3 text-nowrap">{{ $item->name }}</label>
|
||||
<div class="flex flex-wrap items-baseline w-full">
|
||||
<div class="flex flex-col items-start gap-4"
|
||||
style="margin-top: 10px">
|
||||
<div class="flex flex-col items-start gap-4" style="margin-top: 10px">
|
||||
@foreach ($basicData['spekBangunan'] as $spek)
|
||||
@if ($spek->spek_kategori_bangunan_id == $item->id)
|
||||
<label class="form-label flex items-center gap-2.5">
|
||||
@@ -231,16 +229,19 @@
|
||||
</label>
|
||||
@endif
|
||||
@endforeach
|
||||
<label class="form-label flex items-center gap-2.5 mt-2">
|
||||
<input class=input" type="text"
|
||||
name="spek_bangunan[0][{{ $item->name }}][lainnya]"
|
||||
placeholder="Lainnya (sebutkan)">
|
||||
</label>
|
||||
</div>
|
||||
<em id="error-spek_bangunan_{{ $item->name }}"
|
||||
class="alert text-danger text-sm"></em>
|
||||
<em id="error-spek_bangunan_{{ $item->name }}" class="alert text-danger text-sm"></em>
|
||||
</div>
|
||||
</div>
|
||||
@endforeach
|
||||
@endif
|
||||
</div>
|
||||
<button type="button" class="mt-2 btn btn-danger btn-outline btn-xs delete-button"
|
||||
style="display: none;">Hapus</button>
|
||||
<button type="button" class="mt-2 btn btn-danger btn-outline btn-xs delete-button" style="display: none;">Hapus</button>
|
||||
</div>
|
||||
@endif
|
||||
</div>
|
||||
@@ -252,10 +253,10 @@
|
||||
<i class="ki-filled ki-plus"></i>
|
||||
</button>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<!-- Sarana pelengkap -->
|
||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||
<label class="form-label max-w-56">Sarana Pelengkap</label>
|
||||
@@ -326,7 +327,7 @@
|
||||
input.name = `spek_bangunan[${index}][${matches[1]}][]`;
|
||||
}
|
||||
} else {
|
||||
// Handle other array inputs
|
||||
// Handle lainnya array inputs
|
||||
input.name = input.name.replace(/\[\d*\]/, `[${index}]`);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -150,6 +150,42 @@
|
||||
<td colspan="3" class="px-4 py-2 font-semibold">Informasi</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="px-4 py-2">Hak atas properti yang dialihkan</td>
|
||||
<td class="px-4 py-2">
|
||||
<input type="text" name="hak_properti" class="input"
|
||||
value="{{ $inspectionData['asset']['hak_properti'] ?? '' }}">
|
||||
</td>
|
||||
<td class="px-4 py-2">
|
||||
<input type="text" name="hak_properti_pembanding[]"
|
||||
class="input">
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td class="px-4 py-2">Penawaran/ Transaksi</td>
|
||||
<td class="px-4 py-2">
|
||||
<input type="text" name="penawaran" class="input"
|
||||
value="{{ $inspectionData['asset']['penawaran'] ?? '' }}">
|
||||
</td>
|
||||
<td class="px-4 py-2">
|
||||
<input type="text" name="penawaran_pembanding[]"
|
||||
class="input">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
|
||||
<tr>
|
||||
<td class="px-4 py-2">Telepon Contact Person</td>
|
||||
<td class="px-4 py-2">
|
||||
<input type="text" name="telepon" class="input"
|
||||
value="{{ $inspectionData['asset']['telepon'] ?? '' }}">
|
||||
</td>
|
||||
<td class="px-4 py-2">
|
||||
<input type="text" name="telepon_pembanding[]"
|
||||
class="input">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="px-4 py-2">Status Narasumber</td>
|
||||
<td class="px-4 py-2">
|
||||
@@ -487,7 +523,9 @@
|
||||
|
||||
// Ambil nilai numerik dari input
|
||||
const harga = parseFloat(hargaInput.value.replace(/[^\d]/g, '') || '0');
|
||||
let diskon = parseFloat(diskonInput.value.replace(/[^\d]/g, '') || '0');
|
||||
let diskonInput_value = diskonInput.value.replace(',', '.');
|
||||
let diskon = parseFloat(diskonInput_value.replace(/[^\d.]/g, '') || '0');
|
||||
|
||||
|
||||
// Batasi diskon maksimal 100%
|
||||
diskon = Math.min(diskon, 100);
|
||||
@@ -546,6 +584,9 @@
|
||||
'harga_diskon_pembanding[]': data.harga_diskon,
|
||||
'total_pembanding[]': data.total,
|
||||
'diskon_pembanding[]': data.diskon,
|
||||
'hak_properti_pembanding[]': data.hak_properti,
|
||||
'telepon_pembanding[]': data.telepon,
|
||||
'penawaran_pembanding[]': data.penawaran,
|
||||
};
|
||||
|
||||
Object.entries(inputs).forEach(([name, value]) => {
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
{{-- analisa fakta --}}
|
||||
<div class="card bg-white rounded-lg overflow-hidden">
|
||||
<div class="card rounded-lg overflow-hidden">
|
||||
<div class="card-header">
|
||||
<h3 class="card-title uppercase">
|
||||
Analisis Fakta
|
||||
|
||||
@@ -386,15 +386,20 @@
|
||||
<div id="inputContainerLantai" class="w-full">
|
||||
<div class="flex w-full items-center justify-center gap-4">
|
||||
<label class="form-label max-w-56">
|
||||
<span class="form-label">Foto Lantai 1</span>
|
||||
<span class="form-label">Foto Lantai {{ $loop->iteration }}</span>
|
||||
</label>
|
||||
<div class="input-group w-full grid gap-5">
|
||||
<img src="{{ asset('storage/' . old('foto_lantai_unit', $item['foto_lantai_unit'])) }}"
|
||||
alt="Gambar Pendamping" style="width: 30rem;">
|
||||
<div class="preview-container">
|
||||
<img id="foto_lantai-preview-{{ $loop->index }}"
|
||||
src="{{ asset('storage/' . old('foto_lantai_unit', $item['foto_lantai_unit'])) }}"
|
||||
alt="Foto Lantai" class="mt-2 h-auto"
|
||||
style="{{ old('foto_lantai_unit', $item['foto_lantai_unit']) ? 'display: block;' : 'display: none;' }} width: 30rem;">
|
||||
|
||||
</div>
|
||||
<input type="hidden" name="name_lantai_unit[]" value="lantai">
|
||||
<input id="inputLantai" type="file" name="foto_lantai_unit[]"
|
||||
class="file-input file-input-bordered w-full" accept="image/*"
|
||||
capture="camera">
|
||||
onchange="previewImage(this, 'foto_lantai-preview')" capture="camera">
|
||||
<button type="button" class="btn btn-danger btn-sm delete-btn"
|
||||
style="display: none;" id="btnDelete">
|
||||
<i class="ki-filled ki-trash"></i>
|
||||
@@ -412,9 +417,16 @@
|
||||
</label>
|
||||
<div class="input-group w-full flex gap-2">
|
||||
<input type="hidden" name="name_lantai_unit[]" value="lantai">
|
||||
<div class="preview-container">
|
||||
<img id="foto_lantai-preview-{{ $loop->index }}"
|
||||
src="{{ asset('storage/' . old('foto_lantai_unit', $item['foto_lantai_unit'])) }}"
|
||||
alt="Foto Lantai" class="mt-2 h-auto"
|
||||
style="{{ old('foto_lantai_unit', $item['foto_lantai_unit']) ? 'display: block;' : 'display: none;' }} width: 30rem;">
|
||||
|
||||
</div>
|
||||
<input id="inputLantai" type="file" name="foto_lantai_unit[]"
|
||||
class="file-input file-input-bordered w-full" accept="image/*"
|
||||
capture="camera">
|
||||
onchange="previewImage(this, 'foto_lantai-preview')" capture="camera">
|
||||
<button type="button" id="btnCamera" class="btn btn-light"
|
||||
data-modal-toggle="#cameraModal">
|
||||
<i class="ki-outline ki-abstract-33"></i> Camera
|
||||
@@ -498,8 +510,7 @@
|
||||
<input id="inputLingkungan_{{ $key }}" type="file"
|
||||
name="foto_lingkungan[]" class="file-input file-input-bordered w-full"
|
||||
accept="image/*" capture="camera"
|
||||
onchange="previewImage(this, 'foto_lingkungan_preview_{{ $key }}')"
|
||||
>
|
||||
onchange="previewImage(this, 'foto_lingkungan_preview_{{ $key }}')">
|
||||
<button type="button" id="btnCamera" class="btn btn-light"
|
||||
data-modal-toggle="#cameraModal">
|
||||
<i class="ki-outline ki-abstract-33"></i> Camera
|
||||
@@ -524,7 +535,8 @@
|
||||
<input type="hidden" name="name_lingkungan[]" value="lingkungan">
|
||||
<img id="foto_lingkungan_preview_0"
|
||||
src="{{ isset($formFoto['lingkungan']) ? asset('storage/' . old('lingkungan', $formFoto['lingkungan'])) : '#' }}"
|
||||
alt="Gambar Lingkungan" style="width: 30rem;" onerror="this.style.display='none';">
|
||||
alt="Gambar Lingkungan" style="width: 30rem;"
|
||||
onerror="this.style.display='none';">
|
||||
<input id="inputLingkungan_0" type="file" name="foto_lingkungan[]"
|
||||
class="file-input file-input-bordered w-full" accept="image/*" capture="camera"
|
||||
onchange="previewImage(this, 'foto_lingkungan_preview_0')">
|
||||
@@ -566,11 +578,9 @@
|
||||
<div class="input-group w-full flex gap-2">
|
||||
<input id="inputPendamping" type="file" name="pendamping"
|
||||
class="file-input file-input-bordered w-full" accept="image/*"
|
||||
onchange="previewImage(this, 'pendamping')"
|
||||
capture="camera">
|
||||
onchange="previewImage(this, 'pendamping')" capture="camera">
|
||||
<button type="button" id="btnCamera" class="btn btn-light"
|
||||
data-modal-toggle="#cameraModal"
|
||||
>
|
||||
data-modal-toggle="#cameraModal">
|
||||
<i class="ki-outline ki-abstract-33"></i> Camera
|
||||
</button>
|
||||
</div>
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
<!-- Informasi Tata Ruang -->
|
||||
<div class="card w-full bg-white">
|
||||
<div class="card w-full ">
|
||||
<div class="card-header">
|
||||
<h3 class="card-title uppercase">
|
||||
Informasi Dinas Tata Ruang
|
||||
|
||||
@@ -53,6 +53,9 @@
|
||||
|
||||
@push('scripts')
|
||||
<script type="text/javascript">
|
||||
const datas = @json($forminspeksi);
|
||||
console.log(datas);
|
||||
|
||||
function updateAlamatFields(status) {
|
||||
// Ambil elemen formulir
|
||||
const addressForm = document.getElementById('alamat_form');
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
<div class="card w-full bg-white rounded-lg shadow-md overflow-hidden">
|
||||
<div class="card w-full rounded-lg shadow-md overflow-hidden">
|
||||
<div class="card-header">
|
||||
<h3 class="card-title uppercase">
|
||||
Analisa Lingkungan
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
|
||||
|
||||
<div class="card w-full bg-white rounded-lg shadow-md overflow-hidden">
|
||||
<div class="card w-full rounded-lg shadow-md overflow-hidden">
|
||||
<div class="card-header">
|
||||
<h3 class="card-title uppercase">
|
||||
Analisa Tanah
|
||||
|
||||
@@ -62,19 +62,14 @@
|
||||
class="input tomselect w-full @error('spek_kategori_bangunan_id') border-danger bg-danger-light @enderror"
|
||||
name="spek_kategori_bangunan_id">
|
||||
<option value="">Select Kategori Bangunan</option>
|
||||
@if (isset($spekKategoriBagunan))
|
||||
@if (!empty($spekKategoriBagunan))
|
||||
@foreach ($spekKategoriBagunan as $item)
|
||||
@if (isset($model->spek_kategori_bangunan_id))
|
||||
<option value="{{ $model->spek_kategori_bangunan_id }}"
|
||||
{{ $model->spek_kategori_bangunan_id == $item->id ? 'selected' : '' }}>
|
||||
{{ $item->name }}
|
||||
</option>
|
||||
@else
|
||||
<option value="{{ $item->id }}"
|
||||
{{ old('spek_kategori_bangunan_id') == $item->id ? 'selected' : '' }}>
|
||||
@if (
|
||||
(isset($model->spek_kategori_bangunan_id) && $model->spek_kategori_bangunan_id == $item->id) ||
|
||||
old('spek_kategori_bangunan_id') == $item->id) selected @endif>
|
||||
{{ $item->name }}
|
||||
</option>
|
||||
@endif
|
||||
@endforeach
|
||||
@endif
|
||||
</select>
|
||||
|
||||
@@ -45,6 +45,13 @@
|
||||
<span class="sort"> <span class="sort-label">{{ isset($header[0]) ? $header[0] : '' }}</span>
|
||||
<span class="sort-icon"> </span> </span>
|
||||
</th>
|
||||
@if ($header[1] == 'spek-bangunan')
|
||||
<th class="min-w-[250px]" data-datatable-column="code">
|
||||
<span class="sort"> <span class="sort-label"> Kategori </span>
|
||||
<span class="sort-icon"> </span> </span>
|
||||
</th>
|
||||
|
||||
@endif
|
||||
<th class="min-w-[50px] text-center" data-datatable-column="actions">Action</th>
|
||||
</tr>
|
||||
</thead>
|
||||
@@ -125,6 +132,14 @@
|
||||
name: {
|
||||
title: 'Jenis Aset',
|
||||
},
|
||||
...(header == 'spek-bangunan' && {
|
||||
kategories:{
|
||||
title: 'Kategori',
|
||||
render: (item, data)=>{
|
||||
return data.bangunan_kategori.name;
|
||||
}
|
||||
}
|
||||
}),
|
||||
actions: {
|
||||
title: 'Status',
|
||||
render: (item, data) => {
|
||||
|
||||
@@ -33,25 +33,35 @@
|
||||
}
|
||||
|
||||
|
||||
function formatCurrency(value) {
|
||||
if (!value) return '';
|
||||
function formatCurrency(value, isDiskon = false) {
|
||||
// Konversi value ke string, pastikan bukan null/undefined
|
||||
let stringValue = value === null || value === undefined ? '' : String(value);
|
||||
|
||||
// Jika input adalah elemen, ambil nilainya
|
||||
const numericValue = typeof value === 'string' ? value : value.value;
|
||||
// Ganti koma dengan titik untuk memastikan parsing numerik
|
||||
stringValue = stringValue.replace(/,/g, '.');
|
||||
|
||||
// Hapus semua karakter non-digit
|
||||
const cleanValue = numericValue.toString().replace(/[^\d]/g, '');
|
||||
// Hapus karakter non-numerik kecuali titik
|
||||
let numericValue = stringValue.replace(/[^\d.]/g, '');
|
||||
|
||||
// Format ke currency
|
||||
const formattedValue = new Intl.NumberFormat('id-ID').format(cleanValue);
|
||||
// Parse nilai numerik
|
||||
const parsedValue = parseFloat(numericValue);
|
||||
|
||||
// Jika input adalah elemen, update nilainya
|
||||
if (typeof value !== 'string') {
|
||||
value.value = formattedValue;
|
||||
if (isDiskon) {
|
||||
// Format untuk diskon
|
||||
return isNaN(parsedValue) ? '' : parsedValue.toLocaleString('id-ID', {
|
||||
minimumFractionDigits: 0,
|
||||
maximumFractionDigits: 2
|
||||
});
|
||||
} else {
|
||||
// Format untuk mata uang tanpa desimal
|
||||
return isNaN(parsedValue) ? '' : parsedValue.toLocaleString('id-ID', {
|
||||
minimumFractionDigits: 0,
|
||||
maximumFractionDigits: 0
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
return formattedValue;
|
||||
}
|
||||
|
||||
|
||||
function previewImage(input, previewId) {
|
||||
if (input.files && input.files[0]) {
|
||||
|
||||
@@ -298,6 +298,20 @@
|
||||
$trail->push('Data Permohonan');
|
||||
});
|
||||
|
||||
Breadcrumbs::for('permohonan.show-pembatalan', function (BreadcrumbTrail $trail) {
|
||||
$trail->parent('permohonan.index');
|
||||
$trail->push('Show Pembatalan Permohonan');
|
||||
});
|
||||
|
||||
Breadcrumbs::for('pembatalan', function (BreadcrumbTrail $trail) {
|
||||
$trail->push('Pembatalan', route('pembatalan.index'));
|
||||
});
|
||||
|
||||
Breadcrumbs::for('pembatalan.edit', function (BreadcrumbTrail $trail) {
|
||||
$trail->parent('pembatalan');
|
||||
$trail->push('Show Pembatalan');
|
||||
});
|
||||
|
||||
Breadcrumbs::for('basicdata.region', function (BreadcrumbTrail $trail) {
|
||||
$trail->parent('basicdata');
|
||||
$trail->push('Region', route('basicdata.region.index'));
|
||||
|
||||
@@ -18,6 +18,7 @@ use Modules\Lpj\Http\Controllers\KJPPController;
|
||||
use Modules\Lpj\Http\Controllers\LaporanController;
|
||||
use Modules\Lpj\Http\Controllers\NilaiPlafondController;
|
||||
use Modules\Lpj\Http\Controllers\NocController;
|
||||
use Modules\Lpj\Http\Controllers\PembatalanController;
|
||||
use Modules\Lpj\Http\Controllers\PemilikJaminanController;
|
||||
use Modules\Lpj\Http\Controllers\PenilaianController;
|
||||
use Modules\Lpj\Http\Controllers\PenilaiController;
|
||||
@@ -367,9 +368,16 @@ Route::middleware(['auth'])->group(function () {
|
||||
});
|
||||
|
||||
Route::get('authorization', [PermohonanController::class, 'authorization'])->name('authorization.index');
|
||||
Route::get('permohonan/{id}/pembatalan', [PermohonanController::class, 'showPembatalan'])->name('permohonan.show-pembatalan');
|
||||
Route::post('permohonan/pembatalan', [PermohonanController::class, 'pembatalan'])->name('permohonan.pembatalan');
|
||||
|
||||
Route::resource('permohonan', PermohonanController::class);
|
||||
|
||||
Route::name('pembatalan.')->prefix('pembatalan')->group(function () {
|
||||
Route::get('datatables', [PembatalanController::class, 'dataForDatatables'])->name('datatables');
|
||||
});
|
||||
Route::resource('pembatalan', PembatalanController::class);
|
||||
|
||||
Route::get('authorization', [PermohonanController::class, 'authorization'])->name('authorization.index');
|
||||
Route::get('authorization/datatables', [PermohonanController::class, 'dataForAuthorization'])->name(
|
||||
'authorization.datatables',
|
||||
@@ -539,6 +547,7 @@ Route::middleware(['auth'])->group(function () {
|
||||
|
||||
Route::get('lampiran/{id}', [PenilaiController::class, 'lampiran'])->name('lampiran');
|
||||
Route::get('export/kertas-kerja', [PenilaiController::class, 'export_kertas_kerja'])->name('export.kertas-kerja');
|
||||
Route::get('print-out', [PenilaiController::class, 'print_out'])->name('print-out');
|
||||
|
||||
Route::post('import/kertas-kerja', [PenilaiController::class, 'import_kertas_kerja'])->name('import.kertas-kerja');
|
||||
|
||||
|
||||
Reference in New Issue
Block a user