Merge remote-tracking branch 'composer/tender' into staging

This commit is contained in:
Daeng Deni Mardaeni
2024-12-13 07:38:36 +07:00
26 changed files with 616 additions and 912 deletions

View File

@@ -45,7 +45,17 @@ class KJPPController extends Controller
// Combine KJPP number with branch code // Combine KJPP number with branch code
$fullKjppNumber = $kjppNumber; $fullKjppNumber = $kjppNumber;
return view('lpj::kjpp.create', compact('ijin_usaha', 'jenis_aset', 'provinces', 'fullKjppNumber')); $emailKantor = [];
$namaPimpinan = [];
$nomorHpPimpinan = [];
$namaPicReviewer = [];
$nomorHpPicReviewer = [];
$namaPicAdmin = [];
$nomorHpPicAdmin = [];
$namaPicMarketing = [];
$nomorHpPicMarketing = [];
return view('lpj::kjpp.create', compact('ijin_usaha', 'jenis_aset', 'provinces', 'fullKjppNumber', 'emailKantor', 'namaPimpinan', 'nomorHpPimpinan', 'namaPicReviewer', 'nomorHpPicReviewer', 'namaPicAdmin', 'nomorHpPicAdmin', 'namaPicMarketing', 'nomorHpPicMarketing'));
} }
/** /**
@@ -55,142 +65,54 @@ class KJPPController extends Controller
{ {
$validated = $request->validated(); $validated = $request->validated();
$validated['email_kantor'] = json_encode($validated['email_kantor']);
$validated['nama_pimpinan'] = json_encode($validated['nama_pimpinan']);
$validated['nomor_hp_pimpinan'] = json_encode($validated['nomor_hp_pimpinan']);
$validated['nama_pic_reviewer'] = json_encode($validated['nama_pic_reviewer']);
$validated['nomor_hp_pic_reviewer'] = json_encode($validated['nomor_hp_pic_reviewer']);
$validated['nama_pic_admin'] = json_encode($validated['nama_pic_admin']);
$validated['nomor_hp_pic_admin'] = json_encode($validated['nomor_hp_pic_admin']);
$validated['nama_pic_marketing'] = json_encode($validated['nama_pic_marketing']);
$validated['nomor_hp_pic_marketing'] = json_encode($validated['nomor_hp_pic_marketing']);
// Konversi array ke JSON untuk ijin_usaha_id
$validated['ijin_usaha_id'] = json_encode($validated['ijin_usaha_id']);
if ($validated) { // Konversi jenis_aset_id ke JSON, dengan penanganan array kosong
$detailEmailKantor = []; $validated['jenis_aset_id'] = $validated['jenis_aset_id']
$detailNamaPimpinan = []; ? json_encode($validated['jenis_aset_id'])
$detailNomorPicPimpinan = []; : json_encode([]);
$detailNamaPicReviewer = [];
$detailNomorHpPicReviewer = [];
$detailNamaPicAdmin = [];
$detailNomorHpPicAdmin = [];
$detailNamaPicMarketing = [];
$detailNomorHpPicMarketing = [];
$emailKantor = $request->input('detail_email_kantor.email_kantor', []);
$namaPimpinan = $request->input('detail_nama_pimpinan.nama_pimpinan', []);
$nomorHpPimpinan = $request->input('detail_nomor_hp_pimpinan.nomor_hp_pimpinan', []);
$namaPicReviewer = $request->input('detail_nama_pic_reviewer.nama_pic_reviewer', []);
$nomorHpPicReviewer = $request->input('detail_nomor_hp_pic_reviewer.nomor_hp_pic_reviewer', []);
$namaPicAdmin = $request->input('detail_nama_pic_admin.nama_pic_admin', []);
$nomorHpPicAdmin = $request->input('detail_nomor_hp_pic_admin.nomor_hp_pic_admin', []);
$namaPicMarketing = $request->input('detail_nama_pic_marketing.nama_pic_marketing', []);
$nomorHpPicMarketing = $request->input('detail_nomor_hp_pic_marketing.nomor_hp_pic_marketing', []);
foreach ($emailKantor as $value) {
$detailEmailKantor[] = [
'email_kantor' => $value
];
}
// Encode to JSON and store
$detailEmailKantorJson = json_encode($detailEmailKantor);
// Process detail_nama_pimpinan
foreach ($namaPimpinan as $value) {
$detailNamaPimpinan[] = [
'nama_pimpinan' => $value
];
}
$detailNamaPimpinanJson = json_encode($detailNamaPimpinan);
// Process detail_nomor_pic_pimpinan
foreach ($nomorHpPimpinan as $value) {
$detailNomorPicPimpinan[] = [
'nomor_hp_pimpinan' => $value
];
}
$detailNomorPicPimpinanJson = json_encode($detailNomorPicPimpinan);
// Process detail_nama_pic_reviewer
foreach ($namaPicReviewer as $value) {
$detailNamaPicReviewer[] = [
'nama_pic_reviewer' => $value
];
}
$detailNamaPicReviewerJson = json_encode($detailNamaPicReviewer);
// Process detail_nomor_hp_pic_reviewer
foreach ($nomorHpPicReviewer as $value) {
$detailNomorHpPicReviewer[] = [
'nomor_hp_pic_reviewer' => $value
];
}
$detailNomorHpPicReviewerJson = json_encode($detailNomorHpPicReviewer);
// Process detail_nama_pic_admin
foreach ($namaPicAdmin as $value) {
$detailNamaPicAdmin[] = [
'nama_pic_admin' => $value
];
}
$detailNamaPicAdminJson = json_encode($detailNamaPicAdmin);
// Process detail_nomor_hp_pic_admin
foreach ($nomorHpPicAdmin as $value) {
$detailNomorHpPicAdmin[] = [
'nomor_hp_pic_admin' => $value
];
}
$detailNomorHpPicAdminJson = json_encode($detailNomorHpPicAdmin);
// Process detail_nama_pic_marketing
foreach ($namaPicMarketing as $value) {
$detailNamaPicMarketing[] = [
'nama_pic_marketing' => $value
];
}
$detailNamaPicMarketingJson = json_encode($detailNamaPicMarketing);
// Process detail_nomor_hp_pic_marketing
foreach ($nomorHpPicMarketing as $value) {
$detailNomorHpPicMarketing[] = [
'nomor_hp_pic_marketing' => $value
];
}
$detailNomorHpPicMarketingJson = json_encode($detailNomorHpPicMarketing);
// Handle file attachment
if ($request->hasFile('attachment')) {
$file = $request->file('attachment'); $file = $request->file('attachment');
$filename = $file ? time() . '.' . $file->getClientOriginalExtension() : 'default.pdf'; $filename = time() . '.' . $file->getClientOriginalExtension();
if ($file) { // Simpan file
// Simpan file yang diunggah $file->storeAs('public/uploads_pdf', $filename);
$file->storeAs('public/uploads_pdf', $filename);
} else {
// Salin file default ke lokasi yang diinginkan
Storage::copy('public/test/default.pdf', 'public/uploads_pdf/' . $filename);
}
$validated['detail_email_kantor'] = $detailEmailKantorJson;
$validated['detail_nama_pimpinan'] = $detailNamaPimpinanJson;
$validated['detail_nomor_hp_pimpinan'] = $detailNomorPicPimpinanJson;
$validated['detail_nama_pic_reviewer'] = $detailNamaPicReviewerJson;
$validated['detail_nomor_hp_pic_reviewer'] = $detailNomorHpPicReviewerJson;
$validated['detail_nama_pic_admin'] = $detailNamaPicAdminJson;
$validated['detail_nomor_hp_pic_admin'] = $detailNomorHpPicAdminJson;
$validated['detail_nama_pic_marketing'] = $detailNamaPicMarketingJson;
$validated['detail_nomor_hp_pic_marketing'] = $detailNomorHpPicMarketingJson;
$validated['ijin_usaha_id'] = json_encode($validated['ijin_usaha_id']);
if (empty($validated['jenis_aset_id'])) {
$validated['jenis_aset_id'] = json_encode([]);
} else {
$validated['jenis_aset_id'] = json_encode($validated['jenis_aset_id']);
}
// Tambahkan nama file ke data yang divalidasi
$validated['attachment'] = $filename; $validated['attachment'] = $filename;
} else {
// Gunakan file default jika tidak ada file yang diunggah
$defaultFilename = 'default.pdf';
Storage::copy('public/test/default.pdf', 'public/uploads_pdf/' . $defaultFilename);
$validated['attachment'] = $defaultFilename;
}
// dd($validated); // Hapus baris dd() sebelum membuat record
// dd($validated);
// Simpan data ke database
KJPP::create($validated); try {
// Buat record KJPP
$kjpp = KJPP::create($validated);
return redirect() return redirect()
->route('basicdata.kjpp.index') ->route('basicdata.kjpp.index')
->with('success', 'KJPP created successfully'); ->with('success', 'KJPP created successfully');
} else { } catch (\Exception $e) {
// Tangani kesalahan jika ada
return redirect() return redirect()
->route('basicdata.kjpp.create') ->route('basicdata.kjpp.create')
->with('error', 'Validation failed'); ->with('error', 'Failed to create KJPP: ' . $e->getMessage());
} }
} }
@@ -207,46 +129,18 @@ class KJPPController extends Controller
$cities = City::where('code', $kjpp->city_code)->get(); $cities = City::where('code', $kjpp->city_code)->get();
$districts = District::where('code', $kjpp->district_code)->get(); $districts = District::where('code', $kjpp->district_code)->get();
$villages = Village::where('code', $kjpp->village_code)->get(); $villages = Village::where('code', $kjpp->village_code)->get();
$detailEmailKantor = json_decode($kjpp->detail_email_kantor);
$detailNamaPimpinan = json_decode($kjpp->detail_nama_pimpinan);
$detailNomorHpPimpinan = json_decode($kjpp->detail_nomor_hp_pimpinan);
$detailNamaPicReviewer = json_decode($kjpp->detail_nama_pic_reviewer);
$detailNomorHpPicReviewer = json_decode($kjpp->detail_nomor_hp_pic_reviewer);
$detailNamaPicAdmin = json_decode($kjpp->detail_nama_pic_admin);
$detailNomorHpPicAdmin = json_decode($kjpp->detail_nomor_hp_pic_admin);
$detailNamaPicMarketing = json_decode($kjpp->detail_nama_pic_marketing);
$detailNomorHpPicMarketing = json_decode($kjpp->detail_nomor_hp_pic_marketing);
$detailJoinPimpinan = json_encode(array_map(function ($nama, $nomor) { $emailKantor = json_decode($kjpp->email_kantor);
return [ $namaPimpinan = json_decode($kjpp->nama_pimpinan);
'nama_pimpinan' => $nama->nama_pimpinan, $nomorHpPimpinan = json_decode($kjpp->nomor_hp_pimpinan);
'nomor_hp_pimpinan' => $nomor->nomor_hp_pimpinan $namaPicReviewer = json_decode($kjpp->nama_pic_reviewer);
]; $nomorHpPicReviewer = json_decode($kjpp->nomor_hp_pic_reviewer);
}, $detailNamaPimpinan, $detailNomorHpPimpinan)); $namaPicAdmin = json_decode($kjpp->nama_pic_admin);
$nomorHpPicAdmin = json_decode($kjpp->nomor_hp_pic_admin);
$namaPicMarketing = json_decode($kjpp->nama_pic_marketing);
$nomorHpPicMarketing = json_decode($kjpp->nomor_hp_pic_marketing);
return view('lpj::kjpp.show', compact('jenis_jaminan', 'ijin_usahas', 'ijin_usaha', 'kjpp', 'provinces', 'cities', 'districts', 'villages', 'emailKantor', 'namaPimpinan', 'nomorHpPimpinan', 'namaPicReviewer', 'nomorHpPicReviewer', 'namaPicAdmin', 'nomorHpPicAdmin', 'namaPicMarketing', 'nomorHpPicMarketing'));
$detailJoinPicReviewer = json_encode(array_map(function ($nama, $nomor) {
return [
'nama_pic_reviewer' => $nama->nama_pic_reviewer,
'nomor_hp_pic_reviewer' => $nomor->nomor_hp_pic_reviewer
];
}, $detailNamaPicReviewer, $detailNomorHpPicReviewer));
$detailJoinPicAdmin = json_encode(array_map(function ($nama, $nomor) {
return [
'nama_pic_admin' => $nama->nama_pic_admin,
'nomor_hp_pic_admin' => $nomor->nomor_hp_pic_admin
];
}, $detailNamaPicAdmin, $detailNomorHpPicAdmin));
$detailJoinPicMarketing = json_encode(array_map(function ($nama, $nomor) {
return [
'nama_pic_marketing' => $nama->nama_pic_marketing,
'nomor_hp_pic_marketing' => $nomor->nomor_hp_pic_marketing
];
}, $detailNamaPicMarketing, $detailNomorHpPicMarketing));
return view('lpj::kjpp.show', compact('jenis_jaminan', 'ijin_usahas', 'ijin_usaha', 'kjpp', 'provinces', 'cities', 'districts', 'villages', 'detailEmailKantor', 'detailJoinPicReviewer', 'detailJoinPicAdmin', 'detailJoinPicMarketing', 'detailJoinPimpinan'));
} }
/** /**
@@ -261,49 +155,19 @@ class KJPPController extends Controller
$cities = City::where('province_code', $kjpp->province_code)->get(); $cities = City::where('province_code', $kjpp->province_code)->get();
$districts = District::where('city_code', $kjpp->city_code)->get(); $districts = District::where('city_code', $kjpp->city_code)->get();
$villages = Village::where('district_code', $kjpp->district_code)->get(); $villages = Village::where('district_code', $kjpp->district_code)->get();
$detailEmailKantor = json_decode($kjpp->detail_email_kantor);
$detailNamaPimpinan = json_decode($kjpp->detail_nama_pimpinan);
$detailNomorHpPimpinan = json_decode($kjpp->detail_nomor_hp_pimpinan);
$detailNamaPicReviewer = json_decode($kjpp->detail_nama_pic_reviewer);
$detailNomorHpPicReviewer = json_decode($kjpp->detail_nomor_hp_pic_reviewer);
$detailNamaPicAdmin = json_decode($kjpp->detail_nama_pic_admin);
$detailNomorHpPicAdmin = json_decode($kjpp->detail_nomor_hp_pic_admin);
$detailNamaPicMarketing = json_decode($kjpp->detail_nama_pic_marketing);
$detailNomorHpPicMarketing = json_decode($kjpp->detail_nomor_hp_pic_marketing);
// dd($detailNamaPimpinan); $emailKantor = json_decode($kjpp->email_kantor);
$namaPimpinan = json_decode($kjpp->nama_pimpinan);
$nomorHpPimpinan = json_decode($kjpp->nomor_hp_pimpinan);
$namaPicReviewer = json_decode($kjpp->nama_pic_reviewer);
$nomorHpPicReviewer = json_decode($kjpp->nomor_hp_pic_reviewer);
$namaPicAdmin = json_decode($kjpp->nama_pic_admin);
$nomorHpPicAdmin = json_decode($kjpp->nomor_hp_pic_admin);
$namaPicMarketing = json_decode($kjpp->nama_pic_marketing);
$nomorHpPicMarketing = json_decode($kjpp->nomor_hp_pic_marketing);
$detailJoinPimpinan = json_encode(array_map(function ($nama, $nomor) {
return [
'nama_pimpinan' => $nama->nama_pimpinan,
'nomor_hp_pimpinan' => $nomor->nomor_hp_pimpinan
];
}, $detailNamaPimpinan, $detailNomorHpPimpinan));
// dd($detailJoinPimpinan); return view('lpj::kjpp.create', compact('kjpp', 'ijin_usaha', 'jenis_aset', 'provinces', 'cities', 'districts', 'villages', 'emailKantor', 'namaPimpinan', 'nomorHpPimpinan', 'namaPicReviewer', 'nomorHpPicReviewer', 'namaPicAdmin', 'nomorHpPicAdmin', 'namaPicMarketing', 'nomorHpPicMarketing'));
$detailJoinPicReviewer = json_encode(array_map(function ($nama, $nomor) {
return [
'nama_pic_reviewer' => $nama->nama_pic_reviewer,
'nomor_hp_pic_reviewer' => $nomor->nomor_hp_pic_reviewer
];
}, $detailNamaPicReviewer, $detailNomorHpPicReviewer));
$detailJoinPicAdmin = json_encode(array_map(function ($nama, $nomor) {
return [
'nama_pic_admin' => $nama->nama_pic_admin,
'nomor_hp_pic_admin' => $nomor->nomor_hp_pic_admin
];
}, $detailNamaPicAdmin, $detailNomorHpPicAdmin));
$detailJoinPicMarketing = json_encode(array_map(function ($nama, $nomor) {
return [
'nama_pic_marketing' => $nama->nama_pic_marketing,
'nomor_hp_pic_marketing' => $nomor->nomor_hp_pic_marketing
];
}, $detailNamaPicMarketing, $detailNomorHpPicMarketing));
return view('lpj::kjpp.create', compact('kjpp', 'ijin_usaha', 'jenis_aset', 'provinces', 'cities', 'districts', 'villages', 'detailJoinPicReviewer', 'detailJoinPicAdmin', 'detailJoinPicMarketing', 'detailEmailKantor', 'detailJoinPimpinan'));
} }
/** /**
@@ -313,102 +177,7 @@ class KJPPController extends Controller
{ {
$validated = $request->validated(); $validated = $request->validated();
// dd($validated);
if ($validated) { if ($validated) {
$detailEmailKantor = [];
$detailNamaPimpinan = [];
$detailNomorHpPimpinan = [];
$detailNamaPicReviewer = [];
$detailNomorHpPicReviewer = [];
$detailNamaPicAdmin = [];
$detailNomorHpPicAdmin = [];
$detailNamaPicMarketing = [];
$detailNomorHpPicMarketing = [];
$emailKantor = $request->input('detail_email_kantor.email_kantor', []);
$namaPimpinan = $request->input('detail_nama_pimpinan.nama_pimpinan', []);
$nomorHpPimpinan = $request->input('detail_nomor_hp_pimpinan.nomor_hp_pimpinan', []);
$namaPicReviewer = $request->input('detail_nama_pic_reviewer.nama_pic_reviewer', []);
$nomorHpPicReviewer = $request->input('detail_nomor_hp_pic_reviewer.nomor_hp_pic_reviewer', []);
$namaPicAdmin = $request->input('detail_nama_pic_admin.nama_pic_admin', []);
$nomorHpPicAdmin = $request->input('detail_nomor_hp_pic_admin.nomor_hp_pic_admin', []);
$namaPicMarketing = $request->input('detail_nama_pic_marketing.nama_pic_marketing', []);
$nomorHpPicMarketing = $request->input('detail_nomor_hp_pic_marketing.nomor_hp_pic_marketing', []);
foreach ($emailKantor as $value) {
$detailEmailKantor[] = [
'email_kantor' => $value
];
}
// Encode to JSON and store
$detailEmailKantorJson = json_encode($detailEmailKantor);
// Process detail_nama_pimpinan
foreach ($namaPimpinan as $value) {
$detailNamaPimpinan[] = [
'nama_pimpinan' => $value
];
}
$detailNamaPimpinanJson = json_encode($detailNamaPimpinan);
// Process detail_nomor_hp_pimpinan
foreach ($nomorHpPimpinan as $value) {
$detailNomorHpPimpinan[] = [
'nomor_hp_pimpinan' => $value
];
}
$detailNomorHpPimpinanJson = json_encode($detailNomorHpPimpinan);
// Process detail_nama_pic_reviewer
foreach ($namaPicReviewer as $value) {
$detailNamaPicReviewer[] = [
'nama_pic_reviewer' => $value
];
}
$detailNamaPicReviewerJson = json_encode($detailNamaPicReviewer);
// Process detail_nomor_hp_pic_reviewer
foreach ($nomorHpPicReviewer as $value) {
$detailNomorHpPicReviewer[] = [
'nomor_hp_pic_reviewer' => $value
];
}
$detailNomorHpPicReviewerJson = json_encode($detailNomorHpPicReviewer);
// Process detail_nama_pic_admin
foreach ($namaPicAdmin as $value) {
$detailNamaPicAdmin[] = [
'nama_pic_admin' => $value
];
}
$detailNamaPicAdminJson = json_encode($detailNamaPicAdmin);
// Process detail_nomor_hp_pic_admin
foreach ($nomorHpPicAdmin as $value) {
$detailNomorHpPicAdmin[] = [
'nomor_hp_pic_admin' => $value
];
}
$detailNomorHpPicAdminJson = json_encode($detailNomorHpPicAdmin);
// Process detail_nama_pic_marketing
foreach ($namaPicMarketing as $value) {
$detailNamaPicMarketing[] = [
'nama_pic_marketing' => $value
];
}
$detailNamaPicMarketingJson = json_encode($detailNamaPicMarketing);
// Process detail_nomor_hp_pic_marketing
foreach ($nomorHpPicMarketing as $value) {
$detailNomorHpPicMarketing[] = [
'nomor_hp_pic_marketing' => $value
];
}
$detailNomorHpPicMarketingJson = json_encode($detailNomorHpPicMarketing);
$file = $request->file('attachment'); $file = $request->file('attachment');
$filename = $file ? time() . '.' . $file->getClientOriginalExtension() : null; $filename = $file ? time() . '.' . $file->getClientOriginalExtension() : null;
@@ -428,15 +197,16 @@ class KJPPController extends Controller
$validated['attachment'] = $kjpp->attachment ?? 'default.pdf'; $validated['attachment'] = $kjpp->attachment ?? 'default.pdf';
} }
$validated['detail_email_kantor'] = $detailEmailKantorJson; $validated['email_kantor'] = json_encode($validated['email_kantor']);
$validated['detail_nama_pimpinan'] = $detailNamaPimpinanJson; $validated['nama_pimpinan'] = json_encode($validated['nama_pimpinan']);
$validated['detail_nomor_hp_pimpinan'] = $detailNomorHpPimpinanJson; $validated['nomor_hp_pimpinan'] = json_encode($validated['nomor_hp_pimpinan']);
$validated['detail_nama_pic_reviewer'] = $detailNamaPicReviewerJson; $validated['nama_pic_reviewer'] = json_encode($validated['nama_pic_reviewer']);
$validated['detail_nomor_hp_pic_reviewer'] = $detailNomorHpPicReviewerJson; $validated['nomor_hp_pic_reviewer'] = json_encode($validated['nomor_hp_pic_reviewer']);
$validated['detail_nama_pic_admin'] = $detailNamaPicAdminJson; $validated['nama_pic_admin'] = json_encode($validated['nama_pic_admin']);
$validated['detail_nomor_hp_pic_admin'] = $detailNomorHpPicAdminJson; $validated['nomor_hp_pic_admin'] = json_encode($validated['nomor_hp_pic_admin']);
$validated['detail_nama_pic_marketing'] = $detailNamaPicMarketingJson; $validated['nama_pic_marketing'] = json_encode($validated['nama_pic_marketing']);
$validated['detail_nomor_hp_pic_marketing'] = $detailNomorHpPicMarketingJson; $validated['nomor_hp_pic_marketing'] = json_encode($validated['nomor_hp_pic_marketing']);
$validated['ijin_usaha_id'] = json_encode($validated['ijin_usaha_id']); $validated['ijin_usaha_id'] = json_encode($validated['ijin_usaha_id']);
if (empty($validated['jenis_aset_id'])) { if (empty($validated['jenis_aset_id'])) {
$validated['jenis_aset_id'] = json_encode([]); $validated['jenis_aset_id'] = json_encode([]);
@@ -444,6 +214,8 @@ class KJPPController extends Controller
$validated['jenis_aset_id'] = json_encode($validated['jenis_aset_id']); $validated['jenis_aset_id'] = json_encode($validated['jenis_aset_id']);
} }
// dd($validated);
// Perbarui data di database // Perbarui data di database
KJPP::where('id', $id)->update($validated); KJPP::where('id', $id)->update($validated);

View File

@@ -22,24 +22,43 @@ class KJPPRequest extends FormRequest
'address' => 'required', 'address' => 'required',
'postal_code' => 'nullable|numeric', 'postal_code' => 'nullable|numeric',
'nomor_telepon_kantor' => 'nullable|numeric|digits_between:8,15', 'nomor_telepon_kantor' => 'nullable|numeric|digits_between:8,15',
'email_kantor' => 'required|email',
'detail_email_kantor' => 'nullable', // Validasi email kantor
'nama_pimpinan' => 'required|string|not_regex:/^\d+$/|max:255', 'email_kantor' => 'array',
'detail_nama_pimpinan' => 'nullable', 'email_kantor.*' => 'required|email',
'nomor_hp_pimpinan' => 'required|numeric|digits_between:10,15',
'detail_nomor_pic_pimpinan' => 'nullable', // Validasi nama pimpinan
'nama_pic_reviewer' => 'nullable|string|not_regex:/^\d+$/|max:255', 'nama_pimpinan' => 'array',
'detail_nama_pic_reviewer' => 'nullable', 'nama_pimpinan.*' => 'required|not_regex:/^\d+$/|max:255',
'nomor_hp_pic_reviewer' => 'nullable|numeric|digits_between:10,15',
'detail_nomor_hp_pic_reviewer' => 'nullable', // Validasi nomor HP pimpinan
'nama_pic_admin' => 'nullable|string|not_regex:/^\d+$/|max:255', 'nomor_hp_pimpinan' => 'array',
'detail_nama_pic_admin' => 'nullable', 'nomor_hp_pimpinan.*' => 'required|numeric|digits_between:10,15',
'nomor_hp_pic_admin' => 'nullable|numeric|digits_between:10,15',
'detail_nomor_hp_pic_admin' => 'nullable', // Validasi nama PIC Reviewer
'nama_pic_marketing' => 'nullable|string|not_regex:/^\d+$/|max:255', 'nama_pic_reviewer' => 'nullable|array',
'detail_nama_pic_marketing' => 'nullable', 'nama_pic_reviewer.*' => 'nullable|not_regex:/^\d+$/|max:255',
'nomor_hp_pic_marketing' => 'nullable|numeric|digits_between:10,15',
'detail_nomor_hp_pic_marketing' => 'nullable', // Validasi nomor HP PIC Reviewer
'nomor_hp_pic_reviewer' => 'array',
'nomor_hp_pic_reviewer.*' => 'nullable|numeric|digits_between:10,15',
// Validasi nama PIC Admin
'nama_pic_admin' => 'array',
'nama_pic_admin.*' => 'nullable|not_regex:/^\d+$/|max:255',
// Validasi nomor HP PIC Admin
'nomor_hp_pic_admin' => 'array',
'nomor_hp_pic_admin.*' => 'nullable|numeric|digits_between:10,15',
// Validasi nama PIC Marketing
'nama_pic_marketing' => 'array',
'nama_pic_marketing.*' => 'nullable|not_regex:/^\d+$/|max:255',
// Validasi nomor HP PIC Marketing
'nomor_hp_pic_marketing' => 'array',
'nomor_hp_pic_marketing.*' => 'nullable|numeric|digits_between:10,15',
'ijin_usaha_id' => 'required|array', 'ijin_usaha_id' => 'required|array',
'ijin_usaha_id.*' => 'exists:ijin_usaha,code', 'ijin_usaha_id.*' => 'exists:ijin_usaha,code',
'jenis_aset_id' => 'nullable|array', 'jenis_aset_id' => 'nullable|array',
@@ -67,6 +86,45 @@ class KJPPRequest extends FormRequest
public function messages(): array public function messages(): array
{ {
return [ return [
// Pesan untuk email kantor
'email_kantor.*.required' => 'Email Kantor Wajib diisi!',
'email_kantor.*.email' => 'Email Kantor tidak valid!',
// Pesan untuk nama pimpinan
'nama_pimpinan.*.required' => 'Nama Pimpinan Wajib diisi!',
'nama_pimpinan.*.not_regex' => 'Nama Pimpinan harus berupa huruf!',
'nama_pimpinan.*.max' => 'Nama Pimpinan maksimal 255 huruf!',
// Pesan untuk nomor HP pimpinan
'nomor_hp_pimpinan.*.required' => 'Nomor HP Pimpinan Wajib diisi!',
'nomor_hp_pimpinan.*.numeric' => 'Nomor HP Pimpinan harus berupa angka!',
'nomor_hp_pimpinan.*.digits_between' => 'Nomor HP Pimpinan minimum 10 digit dan maksimum 15 digit!',
// Pesan untuk nama PIC Reviewer
'nama_pic_reviewer.*.not_regex' => 'Nama PIC Reviewer harus berupa huruf!',
'nama_pic_reviewer.*.max' => 'Nama PIC Reviewer maksimal 255 huruf!',
// Pesan untuk nomor HP PIC Reviewer
'nomor_hp_pic_reviewer.*.numeric' => 'Nomor HP PIC Reviewer harus berupa angka!',
'nomor_hp_pic_reviewer.*.digits_between' => 'Nomor HP PIC Reviewer minimum 10 digit dan maksimum 15 digit!',
// Pesan untuk nama PIC Admin
'nama_pic_admin.*.not_regex' => 'Nama PIC Admin harus berupa huruf!',
'nama_pic_admin.*.max' => 'Nama PIC Admin maksimal 255 huruf!',
// Pesan untuk nomor HP PIC Admin
'nomor_hp_pic_admin.*.numeric' => 'Nomor HP PIC Admin harus berupa angka!',
'nomor_hp_pic_admin.*.digits_between' => 'Nomor HP PIC Admin minimum 10 digit dan maksimum 15 digit!',
// Pesan untuk nama PIC Marketing
'nama_pic_marketing.*.not_regex' => 'Nama PIC Marketing harus berupa huruf!',
'nama_pic_marketing.*.max' => 'Nama PIC Marketing maksimal 255 huruf!',
// Pesan untuk nomor HP PIC Marketing
'nomor_hp_pic_marketing.*.numeric' => 'Nomor HP PIC Marketing harus berupa angka!',
'nomor_hp_pic_marketing.*.digits_between' => 'Nomor HP PIC Marketing minimum 10 digit dan maksimum 15 digit!',
// Pesan lainnya tetap sama
'code.required' => 'Kode KJPP Wajib diisi!', 'code.required' => 'Kode KJPP Wajib diisi!',
'code.max' => 'Kode KJPP maksimal 255 huruf!', 'code.max' => 'Kode KJPP maksimal 255 huruf!',
'code.unique' => 'Kode KJPP tidak boleh sama!', 'code.unique' => 'Kode KJPP tidak boleh sama!',
@@ -81,22 +139,6 @@ class KJPPRequest extends FormRequest
'address.required' => 'Alamat Kantor Wajib diisi!', 'address.required' => 'Alamat Kantor Wajib diisi!',
'nomor_telepon_kantor.numeric' => 'Nomor Telepon Kantor harus berupa angka!', 'nomor_telepon_kantor.numeric' => 'Nomor Telepon Kantor harus berupa angka!',
'nomor_telepon_kantor.digits_between' => 'Nomor Telepon Kantor minimum 8 digit dan maksimum 15 digit!', 'nomor_telepon_kantor.digits_between' => 'Nomor Telepon Kantor minimum 8 digit dan maksimum 15 digit!',
'email_kantor.required' => 'Email Kantor Wajib diisi!',
'email_kantor.email' => 'Email Kantor tidak valid!',
'nama_pimpinan.required' => 'Nama Pimpinan Wajib diisi!',
'nama_pimpinan.not_regex' => 'Nama Pimpinan harus berupa huruf!',
'nomor_hp_pimpinan.required' => 'Nomor HP Pimpinan Wajib diisi!',
'nomor_hp_pimpinan.numeric' => 'Nomor HP Pimpinan harus berupa angka!',
'nomor_hp_pimpinan.digits_between' => 'Nomor HP Pimpinan minimum 10 digit dan maksimum 15 digit!',
'nama_pic_reviewer.not_regex' => 'Nama PIC Reviewer harus berupa huruf!',
'nomor_hp_pic_reviewer.numeric' => 'Nomor HP PIC Reviewer harus berupa angka!',
'nomor_hp_pic_reviewer.digits_between' => 'Nomor HP PIC Reviewer minimum 10 digit dan maksimum 15 digit!',
'nama_pic_admin.not_regex' => 'Nama PIC Admin harus berupa huruf!',
'nomor_hp_pic_admin.numeric' => 'Nomor HP PIC Admin harus berupa angka!',
'nomor_hp_pic_admin.digits_between' => 'Nomor HP PIC Admin minimum 10 digit dan maksimum 15 digit!',
'nama_pic_marketing.not_regex' => 'Nama PIC Marketing harus berupa huruf!',
'nomor_hp_pic_marketing.numeric' => 'Nomor HP PIC Marketing harus berupa angka!',
'nomor_hp_pic_marketing.digits_between' => 'Nomor HP PIC Marketing minimum 10 digit dan maksimum 15 digit!',
'ijin_usaha_id.required' => 'Ijin Usaha Wajib diisi!', 'ijin_usaha_id.required' => 'Ijin Usaha Wajib diisi!',
'attachment.mimes' => 'Attachment harus berformat pdf!', 'attachment.mimes' => 'Attachment harus berformat pdf!',
'attachment.max' => 'Attachment berukuran maksimum 1 MB!', 'attachment.max' => 'Attachment berukuran maksimum 1 MB!',

View File

@@ -0,0 +1,36 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::table('kjpp', function (Blueprint $table) {
$table->dropColumn(['detail_email_kantor', 'detail_nama_pimpinan', 'detail_nomor_hp_pimpinan', 'detail_nama_pic_reviewer', 'detail_nomor_hp_pic_reviewer', 'detail_nama_pic_admin', 'detail_nomor_hp_pic_admin', 'detail_nama_pic_marketing', 'detail_nomor_hp_pic_marketing']);
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::table('kjpp', function (Blueprint $table) {
$table->string('detail_email_kantor')->nullable();
$table->string('detail_nama_pimpinan')->nullable();
$table->string('detail_nomor_hp_pimpinan')->nullable();
$table->string('detail_nama_pic_reviewer')->nullable();
$table->string('detail_nomor_hp_pic_reviewer')->nullable();
$table->string('detail_nama_pic_admin')->nullable();
$table->string('detail_nomor_hp_pic_admin')->nullable();
$table->string('detail_nama_pic_marketing')->nullable();
$table->string('detail_nomor_hp_pic_marketing')->nullable();
});
}
};

View File

@@ -4,7 +4,6 @@ namespace Modules\Lpj\Database\Seeders;
use Illuminate\Database\Seeder; use Illuminate\Database\Seeder;
use Illuminate\Support\Facades\DB; use Illuminate\Support\Facades\DB;
use Modules\Lpj\Models\Debiture;
class DebitureSeeder extends Seeder class DebitureSeeder extends Seeder
{ {
@@ -13,6 +12,6 @@ class DebitureSeeder extends Seeder
*/ */
public function run(): void public function run(): void
{ {
DB::unprepared(file_get_contents(__DIR__ . '/debitures.sql')); DB::unprepared(file_get_contents(__DIR__ . '/sql/debitures.sql'));
} }
} }

View File

@@ -3,7 +3,7 @@
namespace Modules\Lpj\Database\Seeders; namespace Modules\Lpj\Database\Seeders;
use Illuminate\Database\Seeder; use Illuminate\Database\Seeder;
use Modules\Lpj\Models\DetailDokumenJaminan; use Illuminate\Support\Facades\DB;
class DetailDokumenJaminanSeeder extends Seeder class DetailDokumenJaminanSeeder extends Seeder
{ {
@@ -12,62 +12,6 @@ class DetailDokumenJaminanSeeder extends Seeder
*/ */
public function run(): void public function run(): void
{ {
DetailDokumenJaminan::insert([ DB::unprepared(file_get_contents(__DIR__ . '/sql/detail_dokumen_jaminan.sql'));
[
'name' => 'Tanah Bangunan',
'dokumen_jaminan_id' => 1,
'jenis_legalitas_jaminan_id' => 1,
'dokumen_jaminan' => 'jaminan/1/1/Test.pdf',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
'created_by' => 1,
'updated_by' => 1
],
[
'name' => 'Tanah Bangunan',
'dokumen_jaminan_id' => 1,
'jenis_legalitas_jaminan_id' => 3,
'dokumen_jaminan' => 'jaminan/1/1/Test.pdf',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
'created_by' => 1,
'updated_by' => 1
],
[
'name' => 'Tanah Bangunan',
'dokumen_jaminan_id' => 1,
'jenis_legalitas_jaminan_id' => 4,
'dokumen_jaminan' => 'jaminan/1/1/Test.pdf',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
'created_by' => 1,
'updated_by' => 1
],
[
'name' => 'Tanah Bangunan',
'dokumen_jaminan_id' => 1,
'jenis_legalitas_jaminan_id' => 5,
'dokumen_jaminan' => 'jaminan/1/1/Test.pdf',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
'created_by' => 1,
'updated_by' => 1
],
[
'name' => 'Tanah Bangunan',
'dokumen_jaminan_id' => 1,
'jenis_legalitas_jaminan_id' => 6,
'dokumen_jaminan' => 'jaminan/1/1/Test.pdf',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
'created_by' => 1,
'updated_by' => 1
]
]);
} }
} }

View File

@@ -4,7 +4,6 @@ namespace Modules\Lpj\Database\Seeders;
use Illuminate\Database\Seeder; use Illuminate\Database\Seeder;
use Illuminate\Support\Facades\DB; use Illuminate\Support\Facades\DB;
use Modules\Lpj\Models\DokumenJaminan;
class DokumenJaminanSeeder extends Seeder class DokumenJaminanSeeder extends Seeder
{ {
@@ -13,6 +12,6 @@ class DokumenJaminanSeeder extends Seeder
*/ */
public function run(): void public function run(): void
{ {
DB::unprepared(file_get_contents(__DIR__ . '/dokumen_jaminan.sql')); DB::unprepared(file_get_contents(__DIR__ . '/sql/dokumen_jaminan.sql'));
} }
} }

View File

@@ -3,7 +3,7 @@
namespace Modules\Lpj\Database\Seeders; namespace Modules\Lpj\Database\Seeders;
use Illuminate\Database\Seeder; use Illuminate\Database\Seeder;
use Modules\Lpj\Models\IjinUsaha; use Illuminate\Support\Facades\DB;
class IjinUsahaSeeder extends Seeder class IjinUsahaSeeder extends Seeder
{ {
@@ -12,56 +12,6 @@ class IjinUsahaSeeder extends Seeder
*/ */
public function run(): void public function run(): void
{ {
IjinUsaha::insert([ DB::unprepared(file_get_contents(__DIR__ . '/sql/ijin_usaha.sql'));
[
'code' => 'IU001',
'name' => 'Bisnis',
'status' => 1,
'created_at' => now(),
'updated_at' => now()
],
[
'code' => 'IU002',
'name' => 'Properti',
'status' => 1,
'created_at' => now(),
'updated_at' => now()
],
[
'code' => 'IU003',
'name' => 'Personal Properti',
'status' => 1,
'created_at' => now(),
'updated_at' => now()
],
[
'code' => 'IU004',
'name' => 'Properti Sederhana',
'status' => 1,
'created_at' => now(),
'updated_at' => now()
],
[
'code' => 'IU005',
'name' => 'Kep Men Keu RI Nomor 104/KM.1/2018',
'status' => 1,
'created_at' => now(),
'updated_at' => now()
],
[
'code' => 'IU006',
'name' => 'Kep Men Keu RI Nomor 174/KM.1/2018',
'status' => 1,
'created_at' => now(),
'updated_at' => now()
],
[
'code' => 'IU007',
'name' => 'Kep Men Keu RI Nomor 368/KM.1/2020',
'status' => 1,
'created_at' => now(),
'updated_at' => now()
],
]);
} }
} }

View File

@@ -3,7 +3,7 @@
namespace Modules\Lpj\Database\Seeders; namespace Modules\Lpj\Database\Seeders;
use Illuminate\Database\Seeder; use Illuminate\Database\Seeder;
use Modules\Lpj\Models\JenisJaminan; use Illuminate\Support\Facades\DB;
class JenisJaminanSeeder extends Seeder class JenisJaminanSeeder extends Seeder
{ {
@@ -12,187 +12,6 @@ class JenisJaminanSeeder extends Seeder
*/ */
public function run(): void public function run(): void
{ {
JenisJaminan::insert([ DB::unprepared(file_get_contents(__DIR__ . '/sql/jenis_jaminan.sql'));
[
'code' => 'JJ001',
'name' => 'Tanah',
'slug' => 'tanah',
'form_kategori' => '["tanah", "lingkungan", "fakta"]',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ003","JLJ004","JLJ005","JLJ006","JLJ022"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ002',
'name' => 'Unit Apartemen',
'slug' => 'unit-apartemen',
'form_kategori' => '["apartemen-kantor", "lingkungan", "fakta", "informasi"]',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ003","JLJ004","JLJ006","JLJ007","JLJ022","JLJ024"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ003',
'name' => 'Kawasan Industrial / Komersil / Residensial - Perumahan',
'slug' => 'kawasan-industrial-komersil-residensial-perumahan',
'form_kategori' => '["tanah", "bangunan", "lingkungan", "fakta", "informasi"]',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ003","JLJ004","JLJ006","JLJ007","JLJ008","JLJ022"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ004',
'name' => 'Mall',
'slug' => 'mall',
'form_kategori' => 'null',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ003","JLJ004","JLJ006","JLJ007","JLJ009","JLJ012","JLJ013","JLJ014","JLJ015","JLJ021","JLJ022"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ005',
'name' => 'Pabrik',
'slug' => 'pabrik',
'form_kategori' => 'null',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ003","JLJ004","JLJ006","JLJ007","JLJ009","JLJ011"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ006',
'name' => 'Emas dan Perak',
'slug' => 'emas-dan-perak',
'form_kategori' => 'null',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ007","JLJ014","JLJ022"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ007',
'name' => 'Alat Berat',
'slug' => 'alat-berat',
'form_kategori' => 'null',
'jenis_legalitas_jaminan_id' => '["JLJ004"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ008',
'name' => 'Rumah Tinggal',
'slug' => 'rumah-tinggal',
'form_kategori' => '["tanah", "bangunan", "lingkungan", "fakta", "informasi"]',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ003","JLJ004","JLJ006","JLJ007","JLJ009","JLJ024"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ009',
'name' => 'Pabrik',
'slug' => 'pabrik',
'form_kategori' => '["tanah", "bangunan", "lingkungan", "fakta", "informasi"]',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ006","JLJ007","JLJ009"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ010',
'name' => 'Gudang',
'slug' => 'gudang',
'form_kategori' => '["tanah", "bangunan", "lingkungan", "fakta", "informasi"]',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ003","JLJ007","JLJ009","JLJ024"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ011',
'name' => 'Unit Kios',
'slug' => 'unit-kios',
'form_kategori' => '["apartemen-kantor", "lingkungan", "fakta", "informasi"]',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ007","JLJ009","JLJ024"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ012',
'name' => 'Gedung Mall',
'slug' => 'gedung-mall',
'form_kategori' => '["tanah", "bangunan", "lingkungan", "fakta", "informasi"]',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ007","JLJ009"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ013',
'name' => 'Tanah Bangunan',
'slug' => 'tanah-bangunan',
'form_kategori' => '["tanah", "bangunan"]',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ003","JLJ005","JLJ007","JLJ009","JLJ022","JLJ024"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ014',
'name' => 'Apartemen',
'slug' => 'apartemen',
'form_kategori' => '["apartemen-kantor", "lingkungan", "fakta", "informasi"]',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ003","JLJ022","JLJ024"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ015',
'name' => 'Ruko',
'slug' => 'ruko',
'form_kategori' => '["tanah", "bangunan"]',
'jenis_legalitas_jaminan_id' => '["JLJ001","JLJ003","JLJ007","JLJ022"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ016',
'name' => 'Mesin Tekstil',
'slug' => 'mesin-tekstil',
'form_kategori' => '["mesin"]',
'jenis_legalitas_jaminan_id' => '["JLJ011","JLJ022"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ017',
'name' => 'Mesin',
'slug' => 'mesin',
'form_kategori' => '["mesin"]',
'jenis_legalitas_jaminan_id' => '["JLJ011","JLJ022"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
],
[
'code' => 'JJ018',
'name' => 'Mesin Tenun Tekstil',
'slug' => 'mesin-tenun-tekstil',
'form_kategori' => '["mesin"]',
'jenis_legalitas_jaminan_id' => '["JLJ011","JLJ022"]',
'status' => 1,
'created_at' => now(),
'updated_at' => now(),
]
]);
} }
} }

View File

@@ -13,6 +13,6 @@ class JenisLegalitasJaminanSeeder extends Seeder
*/ */
public function run(): void public function run(): void
{ {
DB::unprepared(file_get_contents(__DIR__ . '/jenis_legalitas_jaminan.sql')); DB::unprepared(file_get_contents(__DIR__ . '/sql/jenis_legalitas_jaminan.sql'));
} }
} }

View File

@@ -12,6 +12,6 @@ class KJPPSeeder extends Seeder
*/ */
public function run(): void public function run(): void
{ {
DB::unprepared(file_get_contents(__DIR__ . '/kjpp.sql')); DB::unprepared(file_get_contents(__DIR__ . '/sql/kjpp.sql'));
} }
} }

View File

@@ -30,14 +30,14 @@ class LpjDatabaseSeeder extends Seeder
TeamUsersSeeder::class, TeamUsersSeeder::class,
JenisPenilaianSeeder::class, JenisPenilaianSeeder::class,
IjinUsahaSeeder::class, IjinUsahaSeeder::class,
TujuanPenilaianKJPPSeeder::class, // TujuanPenilaianKJPPSeeder::class,
KJPPSeeder::class, // KJPPSeeder::class,
JenisLaporanSeeder::class, // JenisLaporanSeeder::class,
DebitureSeeder::class, // DebitureSeeder::class,
PemilikJaminanSeeder::class, // PemilikJaminanSeeder::class,
DokumenJaminanSeeder::class, // DokumenJaminanSeeder::class,
DetailDokumenJaminanSeeder::class, // DetailDokumenJaminanSeeder::class,
PermohonanSeeder::class, // PermohonanSeeder::class,
// PenawaranSeeder::class, // PenawaranSeeder::class,
// DetailPenawaranSeeder::class, // DetailPenawaranSeeder::class,
// PenilaianSeeder::class, // PenilaianSeeder::class,

View File

@@ -4,7 +4,6 @@ namespace Modules\Lpj\Database\Seeders;
use Illuminate\Database\Seeder; use Illuminate\Database\Seeder;
use Illuminate\Support\Facades\DB; use Illuminate\Support\Facades\DB;
use Modules\Lpj\Models\PemilikJaminan;
class PemilikJaminanSeeder extends Seeder class PemilikJaminanSeeder extends Seeder
{ {
@@ -13,6 +12,6 @@ class PemilikJaminanSeeder extends Seeder
*/ */
public function run(): void public function run(): void
{ {
DB::unprepared(file_get_contents(__DIR__ . '/pemilik_jaminan.sql')); DB::unprepared(file_get_contents(__DIR__ . '/sql/pemilik_jaminan.sql'));
} }
} }

View File

@@ -13,6 +13,6 @@ class PermohonanSeeder extends Seeder
*/ */
public function run(): void public function run(): void
{ {
DB::unprepared(file_get_contents(__DIR__ . '/permohonan.sql')); DB::unprepared(file_get_contents(__DIR__ . '/sql/permohonan.sql'));
} }
} }

View File

@@ -1,33 +0,0 @@
--
-- Dumping data for table `kjpp`
--
INSERT INTO `kjpp` (`id`, `code`, `name`, `jenis_kantor`, `nomor_ijin_usaha`, `province_code`, `city_code`, `district_code`, `village_code`, `address`, `postal_code`, `nomor_telepon_kantor`, `email_kantor`, `detail_email_kantor`, `nama_pimpinan`, `detail_nama_pimpinan`, `nomor_hp_pimpinan`, `detail_nomor_hp_pimpinan`, `nama_pic_reviewer`, `detail_nama_pic_reviewer`, `nomor_hp_pic_reviewer`, `detail_nomor_hp_pic_reviewer`, `nama_pic_admin`, `detail_nama_pic_admin`, `nomor_hp_pic_admin`, `detail_nomor_hp_pic_admin`, `nama_pic_marketing`, `detail_nama_pic_marketing`, `nomor_hp_pic_marketing`, `detail_nomor_hp_pic_marketing`, `ijin_usaha_id`, `jenis_aset_id`, `attachment`, `status`, `authorized_status`, `authorized_at`, `authorized_by`, `deleted_at`, `deleted_by`, `created_at`, `updated_at`) VALUES
(1, 'K000101', 'Abdullah Fitriantoro dan Rekan', 'Kantor Pusat', '674/KM.1/2009', '31', '31.74', '31.74.06', '31.74.06.1004', 'Komp. Golden Plaza Blok G43-44, Jl. RS. Fatmawati No. 15', '12420', '0217659717', 'admin@kjpp-afr.com', '[]', 'Ir. Abdullah Fitriantoro, M.Sc', '[]', '0811182414', '[]', 'Ir. Agus Hartoyo', '[{\"nama_pic_reviewer\":\"Dwitya Adhi Widagdho, S.T\"},{\"nama_pic_reviewer\":\"Fardia Paramita, S.T, Mec. Dev\"},{\"nama_pic_reviewer\":\"Nurhery Firmansyah, S.P\"}]', '08128099909', '[{\"nomor_hp_pic_reviewer\":\"08174976079\"},{\"nomor_hp_pic_reviewer\":\"08119961910\"},{\"nomor_hp_pic_reviewer\":\"081324783344\"}]', 'Maria Ulfah', '[]', '0811936969', '[]', 'M. Fajar Aristya, S.T', '[]', '085284497868', '[]', '[\"IU002\"]', '[\"JJ013\",\"JJ015\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 16:28:32', '2024-12-05 16:28:32'),
(2, 'K000102', 'Abdullah Fitriantoro dan Rekan', 'Kantor Cabang', '1493/KM.1/2012', '35', '35.78', '35.78.07', '35.78.07.1002', 'Komplek Andhika Plaza A7 Jalan Simpang Dukuh No. 38-40', '60275', '0315473634', 'kjppabdullahsby@yahoo.co.id', '[]', 'Rudi Ardiyanto, S.T', '[]', '08123275094', '[]', 'Joko Wahyudi, S.T', '[]', '081331939212', '[]', 'Maharani Rahma Wati, S.Hum.', '[]', '082335629625', '[]', 'Riski Wulandari Priyantiningrum, S.T.', '[]', '0818377055', '[]', '[\"IU002\"]', '[\"JJ001\",\"JJ008\",\"JJ015\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 16:33:01', '2024-12-05 16:33:01'),
(3, 'K000105', 'Abdullah Fitriantoro dan Rekan', 'Kantor Cabang', '515/KM.1/2014', '12', '12.71', '12.71.02', '12.71.02.1005', 'Jl. Setia Budi Kompk NCC No. 2 C', '20122', '0614155488', 'kjppafr.cabmedan@gmail.com', '[]', 'Juliardi, S.E, MMPP', '[]', '081361522780', '[]', 'Siti Mutiah Hasibuan', '[]', '085297396860', '[]', 'Devi Ruwaidah', '[]', '085358085569', '[]', 'Desti', '[]', '081375743148', '[]', '[\"IU002\"]', '[\"JJ013\",\"JJ007\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 18:26:56', '2024-12-05 18:26:56'),
(4, 'K000106', 'Abdullah Fitriantoro dan Rekan', 'Kantor Cabang', '143/KM.1/2016', '73', '73.71', '73.71.12', '73.71.12.1004', 'Jl. Nipa-Nipa Raya Poros UVRI Ruko Baruga Mas No. 1', '90234', '0411491588', 'addconsulting_mksr@yahoo.co.id', '[]', 'Abdullah Najang, S.Si,', '[]', '082194763932', '[]', 'Erniwati, S.Pd', '[]', '085256101921', '[]', 'Isnaini Chaidir', '[]', '081333595964', '[]', 'Abdullah Najang, S.Si,', '[]', '082194763932', '[]', '[\"IU002\"]', '[\"JJ007\",\"JJ013\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 18:32:21', '2024-12-05 18:32:21'),
(5, 'K000110', 'Abdullah Fitriantoro dan Rekan', 'Kantor Cabang', '159/KM.1/2016', '16', '16.71', '16.71.15', '16.71.15.1003', 'Jl. Drs. H. Achmad Dahlan HY Blok DD No. 11 Rt. 65 Rw. 01', '30151', '0711445110', 'kjppafr_plm@yahoo.co.id', '[{\"email_kantor\":\"palembang@kjpp-afr.com\"}]', 'Jemmy Firdaus, SE,MM', '[]', '081318301479', '[]', 'Danang Pramono Aji, ST', '[]', '082377486639', '[]', 'Mega Ilmiah Nawati, A.Md', '[]', '081367640200', '[]', 'Jemmy Firdaus, SE,MM', '[]', '081318301479', '[]', '[\"IU002\"]', '[\"JJ013\",\"JJ007\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 18:35:34', '2024-12-05 18:35:34'),
(6, 'K000119', 'Abdullah Fitriantoro dan Rekan', 'Kantor Cabang', '1497/KM.1/2012', '14', '14.71', NULL, NULL, 'Jalan T. Tambusai, Komp. Puri Nangka Indah Blok A No. 10', NULL, '0761571351', 'pekanbaru@kjpp-afr.com', '[]', 'Ir. Veny Rinalny', '[]', '081363479523', '[]', 'Benny Mulyono, ST', '[]', '085274482081', '[]', 'Elia Febrina Anggraini, S.IP', '[]', '087899129698', '[]', 'Elia Febrina Anggraini, S.IP', '[]', '087899129698', '[]', '[\"IU002\"]', '[\"JJ007\",\"JJ013\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 18:44:13', '2024-12-05 18:44:13'),
(7, 'K000120', 'Abdullah Fitriantoro dan Rekan', 'Kantor Cabang', '55/KM.1/2018', '15', '15.71', '15.71.02', '15.71.02.1006', 'Jl. Barau-barau II No. 41 RT. 22', '36132', '07413061855', 'afrjambi@gmail.com', '[]', 'Firdaus, SP', '[]', '08126747065', '[]', 'Andri Amzar, S. Kom', '[]', '082375537953', '[]', 'Sri Wahyuni, SE', '[]', '082307799192', '[]', 'Sri Wahyuni, SE', '[]', '082307799192', '[]', '[\"IU004\"]', '[\"JJ007\",\"JJ013\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 18:48:02', '2024-12-05 18:49:43'),
(8, 'K000121', 'Abdullah Fitriantoro dan Rekan', 'Kantor Cabang', '415/KM.1/2016', '13', '13.71', '13.71.02', '13.71.02.1002', 'Jalan Kamang No 22', '25129', '07514774117', 'afrpadang@gmail.com', '[]', 'Abdi Mukhlis, ST', '[]', '082114633346', '[]', 'Veerdes Riyantika', '[]', '082111313667', '[]', 'Nova Novianty', '[]', '082392339144', '[]', 'Desma Sari', '[]', '0811660203', '[]', '[\"IU004\"]', '[\"JJ013\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 18:55:18', '2024-12-05 18:55:18'),
(9, 'K000132', 'Abdullah Fitriantoro dan Rekan', 'Kantor Cabang', '23/KM.1/2023', '81', '81.71', '81.71.04', '81.71.04.2007', 'Dusun Air Sakula Negeri Laha', '97236', '02198259023', 'ambon@kjpp-afr.com', '[]', 'Tri Wawan Setiawan Syarif, S.E', '[]', '085757323769', '[]', 'Tri Wawan Setiawan Syarif, S.E', '[]', '085757323769', '[]', 'Tri Wawan Setiawan Syarif, S.E', '[]', '085757323769', '[]', 'Tri Wawan Setiawan Syarif, S.E', '[]', '085757323769', '[]', '[\"IU004\"]', '[\"JJ013\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 18:58:08', '2024-12-05 18:58:08'),
(10, 'K000201', 'Aksa Nelson dan Rekan', 'Kantor Pusat', 'No. 2.09.0026 SK. Menkeu RI No. 362/KM.1/2009', '31', '31.74', '31.74.05', '31.74.05.1003', 'Asfa Graha, Komp. Cipulir Center Blok A 7, Jl Cildedug Raya No.77', '12230', '0217244222', 'kjpp.aksa.nelson@gmail.com', '[]', 'Aksa Nurdin, SE, MM, MAPPI (Cert)', '[]', '08161383445', '[]', 'Faisal Luthfi S.Kom', '[]', '087883095288', '[]', 'Muhreza Pamungkas', '[]', '081221705542', '[]', 'Herlinda Yunus', '[]', '081288767079', '[]', '[\"IU002\"]', '[\"JJ013\",\"JJ014\",\"JJ015\",\"JJ007\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 19:03:08', '2024-12-05 19:03:08'),
(11, 'K000214', 'Aksa Nelson dan Rekan', 'Kantor Cabang', 'SK. Menkeu RI No. 642/KM.1/2017', '21', '21.71', '21.71.10', '21.71.10.1005', 'Komp. Ruko Permata Niaga Blok E No. 25', '29432', '07783720003', 'batam.kjpp.anr@gmail.com', '[]', 'Fakhry Natsir Muhammad, SE, MAPPI (Cert)', '[]', '081314108580', '[]', 'Wiwing Novia Eka Putri', '[]', '082283391410', '[]', 'Maylisa Zulfiani', '[]', '085364586465', '[]', 'Herlinda Yunus', '[]', '081288767079', '[]', '[\"IU002\"]', '[\"JJ013\",\"JJ014\",\"JJ015\",\"JJ007\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 19:06:38', '2024-12-05 19:06:38'),
(12, 'K000216', 'Aksa Nelson dan Rekan', 'Kantor Cabang', 'SK. Menkeu RI No. 921/KM.1/2017', '64', '64.72', '64.72.08', '64.72.08.1004', 'Jl. K.H Damanhuri II Gg. Al Haw No.19 A', '75119', '05412831411', 'kjppaksanelsonsmd@gmail.com', '[]', 'Tajudin Nur, ST, MAPPI (Cert)', '[]', '081347333309', '[]', 'Juhairyan Noor', '[]', '085247072425', '[]', 'Ali Muhidin', '[]', '081251771158', '[]', 'Herlinda Yunus', '[]', '081288767079', '[]', '[\"IU004\"]', '[\"JJ013\",\"JJ014\",\"JJ015\",\"JJ007\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 19:17:27', '2024-12-05 19:17:27'),
(13, 'K000233', 'Aksa Nelson dan Rekan', 'Kantor Cabang', 'SK. Menkeu RI No. 334/KM.1/2018', '35', '35.25', NULL, NULL, 'Perum. Bakti Pertiwi Kulon, Jl Ikan Belanak 3 No.2', NULL, '0313983014', 'kjppanr.sby@gmail.com', '[]', 'Indar Mardhika, ST, MAPPI (Cert)', '[]', '085257834770', '[]', 'Ir. Umardani', '[]', '08123266552', '[]', 'Maulidiyah Aliefia Rachma', '[]', '0895340839413', '[]', 'Herlinda Yunus', '[]', '081288767079', '[]', '[\"IU004\"]', '[\"JJ013\",\"JJ014\",\"JJ015\",\"JJ007\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 19:22:14', '2024-12-05 19:22:14'),
(14, 'K000301', 'Andi Tiffani dan Rekan', 'Kantor Pusat', 'No. Izin KJPP : 2.19.0157 d/h KMK No 40/KM.1/2019 KM1 No 322 Tahun 2020', '31', '31.75', '31.75.06', '31.75.06.1004', 'Rukan Avenue No. 8-179 Jakarta Garden City', '13910', '02122133629', 'kjppandi01@gmai.com', '[]', 'Andi Iswitardiyanto, S.E., M.Ec.Dev., MAPPI (Cert.)', '[]', '081328477774', '[]', 'Dodi Kristianjati', '[]', '081227600936', '[]', 'Noni Ulpa', '[]', '081293870505', '[]', 'Dodi Kristianjati', '[]', '081227600936', '[]', '[\"IU002\"]', '[\"JJ013\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 19:31:41', '2024-12-05 19:31:41'),
(15, 'K000302', 'Andi Tiffani dan Rekan', 'Kantor Cabang', 'KM1 No 325 Tahun 2020', '35', '35.78', '35.78.04', '35.78.04.1004', 'Jalan Ngagel Tirto Gg.IV nomor 73 B RT.007 RW.003', '60245', '082135058849', 'kjppatr.sby@gmail.com', '[]', 'Johannes Indarga Hary Pratomo, S.H., MAPPI (Cert.)', '[]', '082135058849', '[]', 'M Isa Syaiful', '[]', '081327538844', '[]', 'Thressia Ika W', '[]', '082225199128', '[]', 'M Isa Syaiful', '[]', '081327538844', '[]', '[\"IU002\"]', '[\"JJ013\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 19:34:34', '2024-12-05 19:34:34'),
(16, 'K000304', 'Andi Tiffani dan Rekan', 'Kantor Cabang', 'KM1 No 323 Tahun 2020', '33', '33.74', '33.74.08', '33.74.08.1003', 'Jalan Dr. Wahidin No. 1 RT 1/RW 04', '50253', '02176425015', 'kjppatr.smg@gmail.com', '[]', 'Ruly Ayu Permatasari, S.Pd., MAPPI (Cert.)', '[]', '082231163596', '[]', 'Tyas Sulaksito', '[]', '082134565313', '[]', 'Farida Muryani', '[]', '085713418165', '[]', 'Dionysius Novian Adri Wicaksana', '[]', '082133938636', '[]', '[\"IU002\"]', '[\"JJ013\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 19:37:27', '2024-12-05 19:37:27'),
(17, 'K000313', 'Andi Tiffani dan Rekan', 'Kantor Cabang', 'KM1 No 324 Tahun 2020', '34', '34.04', '34.04.07', '34.04.07.2002', 'Jalan Raya Tajem No. 57 Dusun Tajem RT 03/RW 31', '55282', '02744362632', 'kjppatr.yk@gmail.com', '[]', 'Caecilia Tiffani Hindriyana Putri, S.E., M.Ec.Dev., MAPPI (Cert.)', '[]', '081383027001', '[]', 'Agung Irfan Asyari', '[]', '085328446961', '[]', 'Uul Fatayatun', '[]', '085725804171', '[]', 'Makky Roihan', '[]', '085726669797', '[]', '[\"IU002\"]', '[\"JJ013\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 19:40:10', '2024-12-05 19:40:10'),
(18, 'K000401', 'Anton dan Rekan', 'Kantor Pusat', '2.18.0151', '32', NULL, NULL, NULL, 'Jl Pasir Impun Atas No.3', '40195', '02287788405', 'kjpp.anton@gmail.com', '[]', 'Anton Debianto, ST,M.Ec.Dev., MAPPI (Cert.)', '[]', '081220022015', '[]', 'Sangadi Nur Widayat, ST', '[]', '089657419435', '[]', 'Diggy Saputra', '[]', '08180900444', '[]', 'Hendra Setiawan S, SE.', '[]', '082216029465', '[]', '[\"IU005\"]', '[\"JJ016\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 19:47:32', '2024-12-05 20:14:54'),
(19, 'K000422', 'Anton dan Rekan', 'Kantor Cabang', '174/Km.1/2018', '32', '32.78', '32.78.02', '32.78.02.1004', 'Jl Ahmad Yani Perum. Bumi Resik Indah Blok B 8 No.15', '46131', '02657528671', 'kjpp.anton.tasimalaya@gmail.com', '[]', 'Taufik Toharli, S.Pd, MAPPI (Cert.)', '[]', '0817624840', '[]', 'Taufik Toharli, S.Pd, MAPPI (Cert.)', '[]', '0817624840', '[]', 'Devi Permadi, S.M.', '[]', '087722121221', '[]', 'Bambang Setiawan, SE.', '[]', '082240083003', '[]', '[\"IU006\"]', '[]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 20:19:39', '2024-12-05 20:19:56'),
(20, 'K000423', 'Anton dan Rekan', 'Kantor Cabang', '368/Km.1/2020', '32', '32.09', '32.09.15', '32.09.15.1011', 'Perum. Taman Kemantren Blok II No.11', '45611', '02318823411', 'kjpp.anton.cirebon@gmail.com', '[]', 'Yudi Yolandi, ST, MAPPI (Cert.)', '[]', '0811221783', '[]', 'Yudi Yolandi, ST, MAPPI (Cert.)', '[]', '0811221783', '[]', 'Aceng Basar', '[]', '082268665958', '[]', 'Dodi Ahdiyat, SE', '[]', '0811200994', '[]', '[\"IU007\"]', '[\"JJ018\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 20:27:05', '2024-12-05 20:27:05'),
(21, 'K000501', 'Ayon Suherman dan Rekan', 'Kantor Pusat', '2.09.0028', '31', '31.74', '31.74.04', '31.74.04.1006', 'Rukan Pejaten, Jl. Pejaten Raya Kav. 2 No. 11', '12510', '02179195004', 'admin.jkt@kjppasr.co.id', '[]', 'Ayon Suherman, S.E., M.Ec.Dev., MAPPI (Cert.)', '[]', '08159160690', '[]', 'Mahpudin', '[{\"nama_pic_reviewer\":\"Ujang Solahudin\"}]', '085778183213', '[{\"nomor_hp_pic_reviewer\":\"081387108382\"}]', 'Anisha', '[]', '0895364631339', '[]', 'Felia', '[]', '089662365885', '[]', '[\"IU002\"]', '[\"JJ007\",\"JJ010\",\"JJ014\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 20:31:25', '2024-12-05 20:31:25'),
(22, 'K000502', 'Ayon Suherman dan Rekan', 'Kantor Cabang', '2.09.0028', '35', '35.78', '35.78.25', '35.78.25.1004', 'Jl. Gunung Anyar Emas III Blok B-15, RT. 001 RW. 008', '60294', '03158283803', 'admin.surabaya@kjppasr.co.id', '[]', 'Nova Naldi Susanto Uga, S.T., MAPPI (Cert.)', '[]', '081230392453', '[]', 'I Putu Bayu Pramita', '[{\"nama_pic_reviewer\":\"Amin Saifudin\"}]', '087853425134', '[{\"nomor_hp_pic_reviewer\":\"081217677294\"}]', 'Dina Nur Alifa', '[]', '083856910791', '[]', 'Heru Kustiawan', '[]', '085230283000', '[]', '[\"IU002\"]', '[\"JJ015\",\"JJ002\",\"JJ011\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 20:35:18', '2024-12-05 20:35:18'),
(23, 'K000503', 'Ayon Suherman dan Rekan', 'Kantor Cabang', '2.09.0028', '32', '32.73', '32.73.22', '32.73.22.1003', 'Jl. Margabaru III No. 4, RT. 004 RW. 005', '40287', '0227503275', 'admin.bandung@kjppasr.co.id', '[]', 'Wawan Trisnawan, S.T., M.T., MAPPI (Cert.)', '[]', '08122128647', '[]', 'Dody Budiman', '[]', '08122152781', '[]', 'Wawan Trisnawan', '[]', '08122128647', '[]', 'Dody Budiman', '[]', '08122152781', '[]', '[\"IU002\"]', '[\"JJ002\",\"JJ011\",\"JJ015\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 20:38:02', '2024-12-05 20:38:02'),
(24, 'K000505', 'Ayon Suherman dan Rekan', 'Kantor Cabang', '2.09.0028', '12', '12.07', '12.07.21', '12.07.21.2007', 'Jl. Pertahanan, Komp. Villa Permata Indah Blok F No. 12', '20361', '06142788492', 'admin.mdn@kjppasr.co.id', '[]', 'Yusrizal, S.T., MAPPI (Cert.)', '[]', '08116246622', '[]', 'Ade Rangga', '[]', '081361331782', '[]', 'M. Aldwin Surya', '[]', '081376153599', '[]', NULL, '[]', NULL, '[]', '[\"IU002\"]', '[\"JJ008\",\"JJ015\",\"JJ002\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 20:40:47', '2024-12-05 20:40:47'),
(25, 'K000507', 'Ayon Suherman dan Rekan', 'Kantor Cabang', '2.09.0028', '51', '51.71', '51.71.01', '51.71.01.2007', 'Jl. Tukad Petanu Residence Blok B.1', '80224', '03814487466', 'admin.denpasar@kjppasr.co.id', '[]', 'Mahrizal Ependi, S.E., MAPPI (Cert.)', '[]', '08129922061', '[]', 'Octaverra', '[{\"nama_pic_reviewer\":\"Okky Rahman\"}]', '087739227060', '[{\"nomor_hp_pic_reviewer\":\"085792333292\"}]', 'Kiki Amalia', '[]', '082236128815', '[]', NULL, '[]', NULL, '[]', '[\"IU002\"]', '[\"JJ015\",\"JJ011\",\"JJ008\",\"JJ014\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 20:57:28', '2024-12-05 20:57:28'),
(26, 'K000516', 'Ayon Suherman dan Rekan', 'Kantor Cabang', '2.09.0028', '64', '64.72', '64.72.05', '64.72.05.1002', 'Pandanwangi Mansion, Pandanwangi 5 Blok S1 No. 5, Cluster Signature, Jl. Abdul Wahab Syahrani RT. 23 RW. 11', '75119', '05412526864', 'kjpp.asr.samarinda@gmail.com', '[]', 'Achmad Fa\'izin, S.T., M.M., MAPPI (Cert.)', '[]', '081381597919', '[]', 'Wahyu Henny K Sapardi', '[]', '085858021626', '[]', 'Putri Aprilia', '[]', '085348234886', '[]', 'Eka Khoirunnisa', '[]', '082156990526', '[]', '[\"IU002\"]', '[\"JJ010\",\"JJ008\",\"JJ015\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 21:00:37', '2024-12-05 21:00:37'),
(27, 'K000534', 'Ayon Suherman dan Rekan', 'Kantor Cabang', '2.09.0028', '32', '32.76', '32.76.05', '32.76.05.1010', 'Ruko Anggrek Blok C1 No. 39, Jalan Boulevard Grand Depok City', '16412', '02177838880', 'admin.dp@kjppasr.co.id', '[{\"email_kantor\":\"admdpk5@gmail.com\"}]', 'Dwi Rohmawati, S.P., MAPPI (Cert.)', '[]', '081315226390', '[]', 'Taufan Bachtiar', '[{\"nama_pic_reviewer\":\"Rusman Maulana\"},{\"nama_pic_reviewer\":\"Eko Haryanto\"}]', '081318979535', '[{\"nomor_hp_pic_reviewer\":\"081336609045\"},{\"nomor_hp_pic_reviewer\":\"085720414543\"}]', 'Dewi Triyana', '[{\"nama_pic_admin\":\"Nur Aini\"}]', '087877666696', '[{\"nomor_hp_pic_admin\":\"08558777790\"}]', 'Ice Rahmawati', '[]', '081284479900', '[]', '[\"IU002\"]', '[\"JJ011\",\"JJ015\",\"JJ014\",\"JJ008\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 21:05:01', '2024-12-05 21:05:01'),
(28, 'K000600', 'Billy Anthony Lie dan Rekan', 'Kantor Pusat', '2.10.0082', '31', '31.71', NULL, NULL, 'Komplek Harmoni Plaza Blok B No. 20-21', NULL, '02163868190', 'kjppbilly@gmail.com', '[{\"email_kantor\":\"bhn@cbn.net.id\"}]', 'Billy Anthony Lie', '[]', '0816848328', '[]', 'Ady Chandra', '[]', '081340432850', '[]', 'Dewi Puspita R', '[]', '085692634080', '[]', 'Poltak Hutajulu', '[{\"nama_pic_marketing\":\"Davin\"},{\"nama_pic_marketing\":\"Reny Asriyani\"}]', '089654423468', '[{\"nomor_hp_pic_marketing\":\"081807900364\"},{\"nomor_hp_pic_marketing\":\"085880205411\"}]', '[\"IU002\"]', '[\"JJ007\",\"JJ005\"]', 'default.pdf', 1, NULL, NULL, NULL, NULL, NULL, '2024-12-05 21:10:47', '2024-12-05 21:10:47');

View File

@@ -0,0 +1,37 @@
-- MySQL dump 10.13 Distrib 8.0.39, for Win64 (x86_64)
--
-- Host: localhost Database: lpj
-- ------------------------------------------------------
-- Server version 8.0.39
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!50503 SET NAMES utf8mb4 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
--
-- Dumping data for table `ijin_usaha`
--
LOCK TABLES `ijin_usaha` WRITE;
/*!40000 ALTER TABLE `ijin_usaha` DISABLE KEYS */;
INSERT INTO `ijin_usaha` VALUES (1,'IU001','Bisnis',1,NULL,NULL,NULL,'2024-12-06 02:16:02','2024-12-06 02:16:02',NULL,NULL),(2,'IU002','Properti',1,NULL,NULL,NULL,'2024-12-06 02:16:02','2024-12-06 02:16:02',NULL,NULL),(3,'IU003','Personal Properti',1,NULL,NULL,NULL,'2024-12-06 02:16:02','2024-12-06 02:16:02',NULL,NULL),(4,'IU004','Properti Sederhana',1,NULL,NULL,NULL,'2024-12-06 02:16:02','2024-12-06 02:16:02',NULL,NULL),(5,'IU005','Kep Men Keu RI Nomor 104/KM.1/2018',1,NULL,NULL,NULL,'2024-12-06 02:16:02','2024-12-06 02:16:02',NULL,NULL),(6,'IU006','Kep Men Keu RI Nomor 174/KM.1/2018',1,NULL,NULL,NULL,'2024-12-06 02:16:02','2024-12-06 02:16:02',NULL,NULL),(7,'IU007','Kep Men Keu RI Nomor 368/KM.1/2020',1,NULL,NULL,NULL,'2024-12-06 02:16:02','2024-12-06 02:16:02',NULL,NULL),(8,'IU008','Full Properti',1,NULL,NULL,NULL,'2024-12-10 15:11:35','2024-12-10 15:11:35',NULL,NULL);
/*!40000 ALTER TABLE `ijin_usaha` ENABLE KEYS */;
UNLOCK TABLES;
/*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */;
/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;
-- Dump completed on 2024-12-11 8:45:19

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@@ -223,31 +223,36 @@
Email Kantor Email Kantor
</label> </label>
<div class="flex flex-wrap items-baseline w-full gap-1.5"> <div class="flex flex-wrap items-baseline w-full gap-1.5">
<input class="input @error('email_kantor') border-danger @enderror" type="text" <input class="input @error('email_kantor.0') border-danger @enderror" type="text"
name="email_kantor" value="{{ $kjpp->email_kantor ?? old('email_kantor') }}"> name="email_kantor[]" value="{{ $emailKantor[0] ?? old('email_kantor.0') }}">
@error('email_kantor') @error('email_kantor.0')
<em class="alert text-danger text-sm">{{ $message }}</em> <em class="alert text-danger text-sm">{{ $message }}</em>
@enderror @enderror
<div id="detail_email_kantor" class="flex flex-wrap items-center w-full gap-2"> <div id="detail_email_kantor" class="flex flex-wrap items-center w-full gap-2">
@if (isset($kjpp->detail_email_kantor)) @if (is_array(old('email_kantor', $emailKantor)) && count(old('email_kantor', $emailKantor)) > 1)
@foreach ($detailEmailKantor as $detail_email_kantor) @foreach (old('email_kantor', $emailKantor) as $index => $email)
<div class="flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full"> @if ($index > 0 && !empty($email))
<div class="flex flex-wrap items-baseline w-full"> <div
<input class="input @error('email_kantor') border-danger @enderror" class="flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full">
type="text" name="detail_email_kantor[email_kantor][]" <div class="flex flex-wrap items-baseline w-full">
value="{{ $detail_email_kantor->email_kantor ?? old('detail_email_kantor.email_kantor') }}"> <input
@error('email_kantor') class="input @error('email_kantor.' . $index) border-danger @enderror"
<em class="alert text-danger text-sm">{{ $message }}</em> type="text" name="email_kantor[]"
@enderror value="{{ old('email_kantor.' . $index, $email) }}">
@error('email_kantor.' . $index)
<em class="alert text-danger text-sm">{{ $message }}</em>
@enderror
</div>
<button type="button"
class="btn btn-danger btn-xs delete-button-edit">Hapus</button>
</div> </div>
<button type="button" @endif
class="btn btn-danger btn-xs delete-button-edit">Hapus</button>
</div>
@endforeach @endforeach
@endif @endif
</div> </div>
<button type="button" id="tambah_email_kantor" class="btn btn-primary btn-xs">Tambah <button type="button" id="tambah_email_kantor" class="btn btn-primary btn-xs">Tambah Email
Email Kantor</button> Kantor</button>
</div> </div>
</div> </div>
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5"> <div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
@@ -255,9 +260,9 @@
Nama Pimpinan Nama Pimpinan
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input @error('nama_pimpinan') border-danger @enderror" type="text" <input class="input @error('nama_pimpinan.0') border-danger @enderror" type="text"
name="nama_pimpinan" value="{{ $kjpp->nama_pimpinan ?? old('nama_pimpinan') }}"> name="nama_pimpinan[]" value="{{ $namaPimpinan[0] ?? old('nama_pimpinan.0') }}">
@error('nama_pimpinan') @error('nama_pimpinan.0')
<em class="alert text-danger text-sm">{{ $message }}</em> <em class="alert text-danger text-sm">{{ $message }}</em>
@enderror @enderror
</div> </div>
@@ -265,47 +270,50 @@
Nomor HP Pimpinan Nomor HP Pimpinan
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input @error('nomor_hp_pimpinan') border-danger @enderror" type="text" <input class="input @error('nomor_hp_pimpinan.0') border-danger @enderror" type="text"
name="nomor_hp_pimpinan" name="nomor_hp_pimpinan[]"
value="{{ $kjpp->nomor_hp_pimpinan ?? old('nomor_hp_pimpinan') }}"> value="{{ $nomorHpPimpinan[0] ?? old('nomor_hp_pimpinan.0') }}">
@error('nomor_hp_pimpinan') @error('nomor_hp_pimpinan.0')
<em class="alert text-danger text-sm">{{ $message }}</em> <em class="alert text-danger text-sm">{{ $message }}</em>
@enderror @enderror
</div> </div>
</div> </div>
<div class="flex items-baseline flex-wrap lg:flex-nowrap"> <div class="flex items-baseline flex-wrap lg:flex-nowrap">
<div id="detail_nama_pimpinan" class="flex flex-wrap items-baseline w-full gap-2.5"> <div id="detail_nama_pimpinan" class="flex flex-wrap items-baseline w-full gap-2.5">
@if (isset($kjpp->detail_nama_pimpinan) && isset($kjpp->detail_nomor_hp_pimpinan)) @if (is_array($namaPimpinan) && is_array(old('nama_pimpinan', $namaPimpinan)))
@foreach (json_decode($detailJoinPimpinan) as $detail_pimpinan) @foreach (old('nama_pimpinan', $namaPimpinan) as $index => $pimpinan)
<div class="flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full"> @php
<label class="form-label max-w-56"> $nomorHp = old('nomor_hp_pimpinan.' . $index, $nomorHpPimpinan[$index] ?? '');
Nama Pimpinan @endphp
</label> @if ($index > 0 && (!empty($pimpinan) || !empty($nomorHp)))
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full">
<input class="input @error('nama_pimpinan') border-danger @enderror" <label class="form-label max-w-56">Nama Pimpinan</label>
type="text" name="detail_nama_pimpinan[nama_pimpinan][]" <div class="flex flex-wrap items-baseline w-full">
value="{{ $detail_pimpinan->nama_pimpinan ?? old('detail_nama_pimpinan.nama_pimpinan') }}"> <input
@error('nama_pimpinan') class="input @error('nama_pimpinan.' . $index) border-danger @enderror"
<em class="alert text-danger text-sm">{{ $message }}</em> type="text" name="nama_pimpinan[]"
@enderror value="{{ old('nama_pimpinan.' . $index, $pimpinan) }}">
@error('nama_pimpinan.' . $index)
<em class="alert text-danger text-sm">{{ $message }}</em>
@enderror
</div>
<label class="form-label max-w-56">Nomor HP Pimpinan</label>
<div class="flex flex-wrap items-baseline w-full">
<input
class="input @error('nomor_hp_pimpinan.' . $index) border-danger @enderror"
type="text" name="nomor_hp_pimpinan[]"
value="{{ $nomorHp }}">
@error('nomor_hp_pimpinan.' . $index)
<em class="alert text-danger text-sm">{{ $message }}</em>
@enderror
</div>
<button type="button"
class="btn btn-danger btn-xs delete-button-edit">Hapus</button>
</div> </div>
<label class="form-label max-w-56"> @endif
Nomor HP Pimpinan
</label>
<div class="flex flex-wrap items-baseline w-full">
<input class="input @error('nomor_hp_pimpinan') border-danger @enderror"
type="text" name="detail_nomor_hp_pimpinan[nomor_hp_pimpinan][]"
value="{{ $detail_pimpinan->nomor_hp_pimpinan ?? old('detail_nomor_hp_pimpinan.nomor_hp_pimpinan') }}">
@error('nomor_hp_pimpinan')
<em class="alert text-danger text-sm">{{ $message }}</em>
@enderror
</div>
<button type="button" class="btn btn-danger btn-xs delete-button-edit">
Hapus
</button>
</div>
@endforeach @endforeach
@endif @endif
</div> </div>
</div> </div>
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5"> <div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
@@ -322,10 +330,10 @@
Nama PIC Reviewer Nama PIC Reviewer
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input @error('nama_pic_reviewer') border-danger @enderror" type="text" <input class="input @error('nama_pic_reviewer.0') border-danger @enderror" type="text"
name="nama_pic_reviewer" name="nama_pic_reviewer[]"
value="{{ $kjpp->nama_pic_reviewer ?? old('nama_pic_reviewer') }}"> value="{{ $namaPicReviewer[0] ?? old('nama_pic_reviewer.0') }}">
@error('nama_pic_reviewer') @error('nama_pic_reviewer.0')
<em class="alert text-danger text-sm">{{ $message }}</em> <em class="alert text-danger text-sm">{{ $message }}</em>
@enderror @enderror
</div> </div>
@@ -333,46 +341,61 @@
Nomor HP PIC Reviewer Nomor HP PIC Reviewer
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input @error('nomor_hp_pic_reviewer') border-danger @enderror" type="text" <input class="input @error('nomor_hp_pic_reviewer.0') border-danger @enderror"
name="nomor_hp_pic_reviewer" type="text" name="nomor_hp_pic_reviewer[]"
value="{{ $kjpp->nomor_hp_pic_reviewer ?? old('nomor_hp_pic_reviewer') }}"> value="{{ $nomorHpPicReviewer[0] ?? old('nomor_hp_pic_reviewer.0') }}">
@error('nomor_hp_pic_reviewer') @error('nomor_hp_pic_reviewer.0')
<em class="alert text-danger text-sm">{{ $message }}</em> <em class="alert text-danger text-sm">{{ $message }}</em>
@enderror @enderror
</div> </div>
</div> </div>
<div class="flex items-baseline flex-wrap lg:flex-nowrap"> <div class="flex items-baseline flex-wrap lg:flex-nowrap">
<div id="detail_nama_pic_reviewer" class="flex flex-wrap items-baseline w-full gap-2.5"> <div id="detail_nama_pic_reviewer" class="flex flex-wrap items-baseline w-full gap-2.5">
@if (isset($kjpp->detail_nama_pic_reviewer) && isset($kjpp->detail_nomor_hp_pic_reviewer)) @if (is_array(old('nama_pic_reviewer', $namaPicReviewer)) && is_array(old('nomor_hp_pic_reviewer', $nomorHpPicReviewer)))
@foreach (json_decode($detailJoinPicReviewer) as $detail_pic_reviewer) @foreach (old('nama_pic_reviewer', $namaPicReviewer) as $index => $picReviewer)
<div class="flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full"> @php
<label class="form-label max-w-56"> $nomorHpReviewer = old(
Nama PIC Reviewer 'nomor_hp_pic_reviewer.' . $index,
</label> $nomorHpPicReviewer[$index] ?? '',
<div class="flex flex-wrap items-baseline w-full"> );
<input class="input @error('nama_pic_reviewer') border-danger @enderror" @endphp
type="text" name="detail_nama_pic_reviewer[nama_pic_reviewer][]" @if ($index > 0 && (!empty($picReviewer) || !empty($nomorHpReviewer)))
value="{{ $detail_pic_reviewer->nama_pic_reviewer ?? old('detail_nama_pic_reviewer.nama_pic_reviewer') }}"> <div class="flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full">
@error('nama_pic_reviewer') <!-- Nama PIC Reviewer -->
<em class="alert text-danger text-sm">{{ $message }}</em> <div
@enderror class="flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full">
<label class="form-label max-w-56">Nama PIC Reviewer</label>
<div class="flex flex-wrap items-baseline w-full">
<input
class="input @error('nama_pic_reviewer.' . $index) border-danger @enderror"
type="text" name="nama_pic_reviewer[]"
value="{{ old('nama_pic_reviewer.' . $index, $picReviewer) }}">
@error('nama_pic_reviewer.' . $index)
<em class="alert text-danger text-sm">{{ $message }}</em>
@enderror
</div>
</div>
<!-- Nomor HP PIC Reviewer -->
<div
class="flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full">
<label class="form-label max-w-56">Nomor HP PIC Reviewer</label>
<div class="flex flex-wrap items-baseline w-full">
<input
class="input @error('nomor_hp_pic_reviewer.' . $index) border-danger @enderror"
type="text" name="nomor_hp_pic_reviewer[]"
value="{{ $nomorHpReviewer }}">
@error('nomor_hp_pic_reviewer.' . $index)
<em class="alert text-danger text-sm">{{ $message }}</em>
@enderror
</div>
</div>
<!-- Tombol Hapus -->
<button type="button"
class="btn btn-danger btn-xs delete-button-edit">Hapus</button>
</div> </div>
<label class="form-label max-w-56"> @endif
Nomor HP PIC Reviewer
</label>
<div class="flex flex-wrap items-baseline w-full">
<input class="input @error('nomor_hp_pic_reviewer') border-danger @enderror"
type="text"
name="detail_nomor_hp_pic_reviewer[nomor_hp_pic_reviewer][]"
value="{{ $detail_pic_reviewer->nomor_hp_pic_reviewer ?? old('detail_nomor_hp_pic_reviewer.nomor_hp_pic_reviewer') }}">
@error('nomor_hp_pic_reviewer')
<em class="alert text-danger text-sm">{{ $message }}</em>
@enderror
</div>
<button type="button" class="btn btn-danger btn-xs delete-button-edit">
Hapus
</button>
</div>
@endforeach @endforeach
@endif @endif
</div> </div>
@@ -391,9 +414,9 @@
Nama PIC Admin Nama PIC Admin
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input @error('nama_pic_admin') border-danger @enderror" type="text" <input class="input @error('nama_pic_admin.0') border-danger @enderror" type="text"
name="nama_pic_admin" value="{{ $kjpp->nama_pic_admin ?? old('nama_pic_admin') }}"> name="nama_pic_admin[]" value="{{ $namaPicAdmin[0] ?? old('nama_pic_admin.0') }}">
@error('nama_pic_admin') @error('nama_pic_admin.0')
<em class="alert text-danger text-sm">{{ $message }}</em> <em class="alert text-danger text-sm">{{ $message }}</em>
@enderror @enderror
</div> </div>
@@ -401,45 +424,55 @@
Nomor HP PIC Admin Nomor HP PIC Admin
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input @error('nomor_hp_pic_admin') border-danger @enderror" type="text" <input class="input @error('nomor_hp_pic_admin.0') border-danger @enderror" type="text"
name="nomor_hp_pic_admin" name="nomor_hp_pic_admin[]"
value="{{ $kjpp->nomor_hp_pic_admin ?? old('nomor_hp_pic_admin') }}"> value="{{ $nomorHpPicAdmin[0] ?? old('nomor_hp_pic_admin.0') }}">
@error('nomor_hp_pic_admin') @error('nomor_hp_pic_admin.0')
<em class="alert text-danger text-sm">{{ $message }}</em> <em class="alert text-danger text-sm">{{ $message }}</em>
@enderror @enderror
</div> </div>
</div> </div>
<div class="flex items-baseline flex-wrap lg:flex-nowrap"> <div class="flex items-baseline flex-wrap lg:flex-nowrap">
<div id="detail_nama_pic_admin" class="flex flex-wrap items-baseline w-full gap-2.5"> <div id="detail_nama_pic_admin" class="flex flex-wrap items-baseline w-full gap-2.5">
@if (isset($kjpp->detail_nama_pic_admin) && isset($kjpp->detail_nomor_hp_pic_admin)) @if (is_array(old('nama_pic_admin', $namaPicAdmin)) && is_array(old('nomor_hp_pic_admin', $nomorHpPicAdmin)))
@foreach (json_decode($detailJoinPicAdmin) as $detail_pic_admin) @foreach (old('nama_pic_admin', $namaPicAdmin) as $index => $picAdmin)
<div class="flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full"> @php
<label class="form-label max-w-56"> $nomorHpAdmin = old(
Nama PIC Admin 'nomor_hp_pic_admin.' . $index,
</label> $nomorHpPicAdmin[$index] ?? '',
<div class="flex flex-wrap items-baseline w-full"> );
<input class="input @error('nama_pic_admin') border-danger @enderror" @endphp
type="text" name="detail_nama_pic_admin[nama_pic_admin][]" @if ($index > 0 && (!empty($picAdmin) || !empty($nomorHpAdmin)))
value="{{ $detail_pic_admin->nama_pic_admin ?? old('detail_nama_pic_admin.nama_pic_admin') }}"> <div class="flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full">
@error('nama_pic_admin') <!-- Nama PIC Admin -->
<em class="alert text-danger text-sm">{{ $message }}</em> <label class="form-label max-w-56">Nama PIC Admin</label>
@enderror <div class="flex flex-wrap items-baseline w-full">
<input
class="input @error('nama_pic_admin.' . $index) border-danger @enderror"
type="text" name="nama_pic_admin[]"
value="{{ old('nama_pic_admin.' . $index, $picAdmin) }}">
@error('nama_pic_admin.' . $index)
<em class="alert text-danger text-sm">{{ $message }}</em>
@enderror
</div>
<!-- Nomor HP PIC Admin -->
<label class="form-label max-w-56">Nomor HP PIC Admin</label>
<div class="flex flex-wrap items-baseline w-full">
<input
class="input @error('nomor_hp_pic_admin.' . $index) border-danger @enderror"
type="text" name="nomor_hp_pic_admin[]"
value="{{ $nomorHpAdmin }}">
@error('nomor_hp_pic_admin.' . $index)
<em class="alert text-danger text-sm">{{ $message }}</em>
@enderror
</div>
<!-- Tombol Hapus -->
<button type="button"
class="btn btn-danger btn-xs delete-button-edit">Hapus</button>
</div> </div>
<label class="form-label max-w-56"> @endif
Nomor HP PIC Admin
</label>
<div class="flex flex-wrap items-baseline w-full">
<input class="input @error('nomor_hp_pic_admin') border-danger @enderror"
type="text" name="detail_nomor_hp_pic_admin[nomor_hp_pic_admin][]"
value="{{ $detail_pic_admin->nomor_hp_pic_admin ?? old('detail_nomor_hp_pic_admin.nomor_hp_pic_admin') }}">
@error('nomor_hp_pic_admin')
<em class="alert text-danger text-sm">{{ $message }}</em>
@enderror
</div>
<button type="button" class="btn btn-danger btn-xs delete-button-edit">
Hapus
</button>
</div>
@endforeach @endforeach
@endif @endif
</div> </div>
@@ -458,10 +491,10 @@
Nama PIC Marketing Nama PIC Marketing
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input @error('nama_pic_marketing') border-danger @enderror" type="text" <input class="input @error('nama_pic_marketing.0') border-danger @enderror" type="text"
name="nama_pic_marketing" name="nama_pic_marketing[]"
value="{{ $kjpp->nama_pic_marketing ?? old('nama_pic_marketing') }}"> value="{{ $namaPicMarketing[0] ?? old('nama_pic_marketing.0') }}">
@error('nama_pic_marketing') @error('nama_pic_marketing.0')
<em class="alert text-danger text-sm">{{ $message }}</em> <em class="alert text-danger text-sm">{{ $message }}</em>
@enderror @enderror
</div> </div>
@@ -469,49 +502,59 @@
Nomor HP PIC Marketing Nomor HP PIC Marketing
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input @error('nomor_hp_pic_marketing') border-danger @enderror" <input class="input @error('nomor_hp_pic_marketing.0') border-danger @enderror"
type="text" name="nomor_hp_pic_marketing" type="text" name="nomor_hp_pic_marketing[]"
value="{{ $kjpp->nomor_hp_pic_marketing ?? old('nomor_hp_pic_marketing') }}"> value="{{ $nomorHpPicMarketing[0] ?? old('nomor_hp_pic_marketing.0') }}">
@error('nomor_hp_pic_marketing') @error('nomor_hp_pic_marketing.0')
<em class="alert text-danger text-sm">{{ $message }}</em> <em class="alert text-danger text-sm">{{ $message }}</em>
@enderror @enderror
</div> </div>
</div> </div>
<div class="flex items-baseline flex-wrap lg:flex-nowrap"> <div class="flex items-baseline flex-wrap lg:flex-nowrap">
<div id="detail_nama_pic_marketing" class="flex flex-wrap items-baseline w-full gap-2.5"> <div id="detail_nama_pic_marketing" class="flex flex-wrap items-baseline w-full gap-2.5">
@if (isset($kjpp->detail_nama_pic_marketing) && isset($kjpp->detail_nomor_hp_pic_marketing)) @if (is_array(old('nama_pic_marketing', $namaPicMarketing)) &&
@foreach (json_decode($detailJoinPicMarketing) as $detail_pic_marketing) is_array(old('nomor_hp_pic_marketing', $nomorHpPicMarketing)))
<div class="flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full"> @foreach (old('nama_pic_marketing', $namaPicMarketing) as $index => $picMarketing)
<label class="form-label max-w-56"> @php
Nama PIC Marketing $nomorHpMarketing = old(
</label> 'nomor_hp_pic_marketing.' . $index,
<div class="flex flex-wrap items-baseline w-full"> $nomorHpPicMarketing[$index] ?? '',
<input class="input @error('nama_pic_marketing') border-danger @enderror" );
type="text" name="detail_nama_pic_marketing[nama_pic_marketing][]" @endphp
value="{{ $detail_pic_marketing->nama_pic_marketing ?? old('detail_nama_pic_marketing.nama_pic_marketing') }}"> @if ($index > 0 && (!empty($picMarketing) || !empty($nomorHpMarketing)))
@error('nama_pic_marketing') <div class="flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full">
<em class="alert text-danger text-sm">{{ $message }}</em> <!-- Nama PIC Marketing -->
@enderror <label class="form-label max-w-56">Nama PIC Marketing</label>
<div class="flex flex-wrap items-baseline w-full">
<input
class="input @error('nama_pic_marketing.' . $index) border-danger @enderror"
type="text" name="nama_pic_marketing[]"
value="{{ old('nama_pic_marketing.' . $index, $picMarketing) }}">
@error('nama_pic_marketing.' . $index)
<em class="alert text-danger text-sm">{{ $message }}</em>
@enderror
</div>
<!-- Nomor HP PIC Marketing -->
<label class="form-label max-w-56">Nomor HP PIC Marketing</label>
<div class="flex flex-wrap items-baseline w-full">
<input
class="input @error('nomor_hp_pic_marketing.' . $index) border-danger @enderror"
type="text" name="nomor_hp_pic_marketing[]"
value="{{ $nomorHpMarketing }}">
@error('nomor_hp_pic_marketing.' . $index)
<em class="alert text-danger text-sm">{{ $message }}</em>
@enderror
</div>
<!-- Tombol Hapus -->
<button type="button"
class="btn btn-danger btn-xs delete-button-edit">Hapus</button>
</div> </div>
<label class="form-label max-w-56"> @endif
Nomor HP PIC Marketing
</label>
<div class="flex flex-wrap items-baseline w-full">
<input
class="input @error('nomor_hp_pic_marketing') border-danger @enderror"
type="text"
name="detail_nomor_hp_pic_marketing[nomor_hp_pic_marketing][]"
value="{{ $detail_pic_marketing->nomor_hp_pic_marketing ?? old('detail_nomor_hp_pic_marketing.nomor_hp_pic_marketing') }}">
@error('nomor_hp_pic_marketing')
<em class="alert text-danger text-sm">{{ $message }}</em>
@enderror
</div>
<button type="button" class="btn btn-danger btn-xs delete-button-edit">
Hapus
</button>
</div>
@endforeach @endforeach
@endif @endif
</div> </div>
</div> </div>
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5"> <div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">

View File

@@ -32,7 +32,7 @@
newDiv.className = "flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full"; newDiv.className = "flex flex-col lg:flex-row gap-2 items-baseline lg:items-center w-full";
newDiv.innerHTML = ` newDiv.innerHTML = `
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input" type="text" name="detail_email_kantor[email_kantor][]" value=""> <input class="input" type="text" name="email_kantor[]" value="">
</div> </div>
<button type="button" class="btn btn-danger btn-xs delete-button">Hapus</button> <button type="button" class="btn btn-danger btn-xs delete-button">Hapus</button>
`; `;
@@ -51,13 +51,13 @@
Nama Pimpinan Nama Pimpinan
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input" type="text" name="detail_nama_pimpinan[nama_pimpinan][]" value=""> <input class="input" type="text" name="nama_pimpinan[]" value="">
</div> </div>
<label class="form-label max-w-56"> <label class="form-label max-w-56">
Nomor HP Pimpinan Nomor HP Pimpinan
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input" type="text" name="detail_nomor_hp_pimpinan[nomor_hp_pimpinan][]" value=""> <input class="input" type="text" name="nomor_hp_pimpinan[]" value="">
</div> </div>
<button type="button" class="btn btn-danger btn-xs delete-button">Hapus</button> <button type="button" class="btn btn-danger btn-xs delete-button">Hapus</button>
`; `;
@@ -76,13 +76,13 @@
Nama PIC Reviewer Nama PIC Reviewer
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input" type="text" name="detail_nama_pic_reviewer[nama_pic_reviewer][]" value=""> <input class="input" type="text" name="nama_pic_reviewer[]" value="">
</div> </div>
<label class="form-label max-w-56"> <label class="form-label max-w-56">
Nomor HP PIC Reviewer Nomor HP PIC Reviewer
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input" type="text" name="detail_nomor_hp_pic_reviewer[nomor_hp_pic_reviewer][]" value=""> <input class="input" type="text" name="nomor_hp_pic_reviewer[]" value="">
</div> </div>
<button type="button" class="btn btn-danger btn-xs delete-button">Hapus</button> <button type="button" class="btn btn-danger btn-xs delete-button">Hapus</button>
`; `;
@@ -101,13 +101,13 @@
Nama PIC Admin Nama PIC Admin
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input" type="text" name="detail_nama_pic_admin[nama_pic_admin][]" value=""> <input class="input" type="text" name="nama_pic_admin[]" value="">
</div> </div>
<label class="form-label max-w-56"> <label class="form-label max-w-56">
Nomor HP PIC Admin Nomor HP PIC Admin
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input" type="text" name="detail_nomor_hp_pic_admin[nomor_hp_pic_admin][]" value=""> <input class="input" type="text" name="nomor_hp_pic_admin[]" value="">
</div> </div>
<button type="button" class="btn btn-danger btn-xs delete-button">Hapus</button> <button type="button" class="btn btn-danger btn-xs delete-button">Hapus</button>
`; `;
@@ -126,13 +126,13 @@
Nama PIC Marketing Nama PIC Marketing
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input" type="text" name="detail_nama_pic_marketing[nama_pic_marketing][]" value=""> <input class="input" type="text" name="nama_pic_marketing[]" value="">
</div> </div>
<label class="form-label max-w-56"> <label class="form-label max-w-56">
Nomor HP PIC Marketing Nomor HP PIC Marketing
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<input class="input" type="text" name="detail_nomor_hp_pic_marketing[nomor_hp_pic_marketing][]" value=""> <input class="input" type="text" name="nomor_hp_pic_marketing[]" value="">
</div> </div>
<button type="button" class="btn btn-danger btn-xs delete-button">Hapus</button> <button type="button" class="btn btn-danger btn-xs delete-button">Hapus</button>
`; `;

View File

@@ -95,13 +95,16 @@
Email Kantor Email Kantor
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<p class="flex w-full text-gray-600 font-medium text-sm">{{ $kjpp->email_kantor }}</p> @if (isset($emailKantor) && count($emailKantor) > 0)
@if (isset($kjpp->detail_email_kantor)) @foreach ($emailKantor as $email)
@foreach (json_decode($kjpp->detail_email_kantor) as $detail_email_kantor)
<p class="flex w-full text-gray-600 font-medium text-sm"> <p class="flex w-full text-gray-600 font-medium text-sm">
{{ $detail_email_kantor->email_kantor }} {{ $email }}
</p> </p>
@endforeach @endforeach
@else
<p class="flex w-full text-gray-600 font-medium text-sm">
-
</p>
@endif @endif
</div> </div>
</div> </div>
@@ -110,26 +113,32 @@
Nama Pimpinan Nama Pimpinan
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<p class="flex w-full text-gray-600 font-medium text-sm">{{ $kjpp->nama_pimpinan }}</p> @if (isset($namaPimpinan) && count($namaPimpinan) > 0)
@if (isset($kjpp->detail_nama_pimpinan)) @foreach ($namaPimpinan as $pimpinan)
@foreach (json_decode($detailJoinPimpinan) as $detail_nama_pimpinan)
<p class="flex w-full text-gray-600 font-medium text-sm"> <p class="flex w-full text-gray-600 font-medium text-sm">
{{ $detail_nama_pimpinan->nama_pimpinan }} {{ $pimpinan }}
</p> </p>
@endforeach @endforeach
@else
<p class="flex w-full text-gray-600 font-medium text-sm">
-
</p>
@endif @endif
</div> </div>
<label class="form-label max-w-56"> <label class="form-label max-w-56">
Nomor HP Pimpinan Nomor HP Pimpinan
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<p class="flex w-full text-gray-600 font-medium text-sm">{{ $kjpp->nomor_hp_pimpinan }}</p> @if (isset($nomorHpPimpinan) && count($nomorHpPimpinan) > 0)
@if (isset($kjpp->detail_nomor_hp_pimpinan)) @foreach ($nomorHpPimpinan as $hp_pimpinan)
@foreach (json_decode($detailJoinPimpinan) as $detail_nomor_hp_pimpinan)
<p class="flex w-full text-gray-600 font-medium text-sm"> <p class="flex w-full text-gray-600 font-medium text-sm">
{{ $detail_nomor_hp_pimpinan->nomor_hp_pimpinan }} {{ $hp_pimpinan }}
</p> </p>
@endforeach @endforeach
@else
<p class="flex w-full text-gray-600 font-medium text-sm">
-
</p>
@endif @endif
</div> </div>
</div> </div>
@@ -138,27 +147,32 @@
Nama PIC Reviewer Nama PIC Reviewer
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<p class="flex w-full text-gray-600 font-medium text-sm">{{ $kjpp->nama_pic_reviewer ?? '-' }}</p> @if (isset($namaPicReviewer) && count($namaPicReviewer) > 0)
@if (isset($kjpp->detail_nama_pic_reviewer)) @foreach ($namaPicReviewer as $pic_reviewer)
@foreach (json_decode($detailJoinPicReviewer) as $detail_nama_pic_reviewer)
<p class="flex w-full text-gray-600 font-medium text-sm"> <p class="flex w-full text-gray-600 font-medium text-sm">
{{ $detail_nama_pic_reviewer->nama_pic_reviewer }} {{ $pic_reviewer }}
</p> </p>
@endforeach @endforeach
@else
<p class="flex w-full text-gray-600 font-medium text-sm">
-
</p>
@endif @endif
</div> </div>
<label class="form-label max-w-56"> <label class="form-label max-w-56">
Nomor HP PIC Reviewer Nomor HP PIC Reviewer
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<p class="flex w-full text-gray-600 font-medium text-sm">{{ $kjpp->nomor_hp_pic_reviewer ?? '-' }} @if (isset($nomorHpPicReviewer) && count($nomorHpPicReviewer) > 0)
</p> @foreach ($nomorHpPicReviewer as $hp_pic_reviewer)
@if (isset($kjpp->detail_nomor_hp_pic_reviewer))
@foreach (json_decode($detailJoinPicReviewer) as $detail_nomor_hp_pic_reviewer)
<p class="flex w-full text-gray-600 font-medium text-sm"> <p class="flex w-full text-gray-600 font-medium text-sm">
{{ $detail_nomor_hp_pic_reviewer->nomor_hp_pic_reviewer }} {{ $hp_pic_reviewer }}
</p> </p>
@endforeach @endforeach
@else
<p class="flex w-full text-gray-600 font-medium text-sm">
-
</p>
@endif @endif
</div> </div>
</div> </div>
@@ -167,26 +181,32 @@
Nama PIC Admin Nama PIC Admin
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<p class="flex w-full text-gray-600 font-medium text-sm">{{ $kjpp->nama_pic_admin ?? '-' }}</p> @if (isset($namaPicAdmin) && count($namaPicAdmin) > 0)
@if (isset($kjpp->detail_nama_pic_admin)) @foreach ($namaPicAdmin as $pic_admin)
@foreach (json_decode($detailJoinPicAdmin) as $detail_nama_pic_admin)
<p class="flex w-full text-gray-600 font-medium text-sm"> <p class="flex w-full text-gray-600 font-medium text-sm">
{{ $detail_nama_pic_admin->nama_pic_admin }} {{ $pic_admin }}
</p> </p>
@endforeach @endforeach
@else
<p class="flex w-full text-gray-600 font-medium text-sm">
-
</p>
@endif @endif
</div> </div>
<label class="form-label max-w-56"> <label class="form-label max-w-56">
Nomor HP PIC Admin Nomor HP PIC Admin
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<p class="flex w-full text-gray-600 font-medium text-sm">{{ $kjpp->nomor_hp_pic_admin ?? '-' }}</p> @if (isset($nomorHpPicAdmin) && count($nomorHpPicAdmin) > 0)
@if (isset($kjpp->detail_nomor_hp_pic_admin)) @foreach ($nomorHpPicAdmin as $hp_pic_admin)
@foreach (json_decode($detailJoinPicAdmin) as $detail_nomor_hp_pic_admin)
<p class="flex w-full text-gray-600 font-medium text-sm"> <p class="flex w-full text-gray-600 font-medium text-sm">
{{ $detail_nomor_hp_pic_admin->nomor_hp_pic_admin }} {{ $hp_pic_admin }}
</p> </p>
@endforeach @endforeach
@else
<p class="flex w-full text-gray-600 font-medium text-sm">
-
</p>
@endif @endif
</div> </div>
</div> </div>
@@ -195,27 +215,32 @@
Nama PIC Marketing Nama PIC Marketing
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<p class="flex w-full text-gray-600 font-medium text-sm">{{ $kjpp->nama_pic_marketing ?? '-' }}</p> @if (isset($namaPicMarketing) && count($namaPicMarketing) > 0)
@if (isset($kjpp->detail_nama_pic_marketing)) @foreach ($namaPicMarketing as $pic_marketing)
@foreach (json_decode($detailJoinPicMarketing) as $detail_nama_pic_marketing)
<p class="flex w-full text-gray-600 font-medium text-sm"> <p class="flex w-full text-gray-600 font-medium text-sm">
{{ $detail_nama_pic_marketing->nama_pic_marketing }} {{ $pic_marketing }}
</p> </p>
@endforeach @endforeach
@else
<p class="flex w-full text-gray-600 font-medium text-sm">
-
</p>
@endif @endif
</div> </div>
<label class="form-label max-w-56"> <label class="form-label max-w-56">
Nomor HP PIC Marketing Nomor HP PIC Marketing
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full">
<p class="flex w-full text-gray-600 font-medium text-sm">{{ $kjpp->nomor_hp_pic_marketing ?? '-' }} @if (isset($nomorHpPicMarketing) && count($nomorHpPicMarketing) > 0)
</p> @foreach ($nomorHpPicMarketing as $hp_pic_marketing)
@if (isset($kjpp->detail_nomor_hp_pic_marketing))
@foreach (json_decode($detailJoinPicMarketing) as $detail_nomor_hp_pic_marketing)
<p class="flex w-full text-gray-600 font-medium text-sm"> <p class="flex w-full text-gray-600 font-medium text-sm">
{{ $detail_nomor_hp_pic_marketing->nomor_hp_pic_marketing }} {{ $hp_pic_marketing }}
</p> </p>
@endforeach @endforeach
@else
<p class="flex w-full text-gray-600 font-medium text-sm">
-
</p>
@endif @endif
</div> </div>
</div> </div>
@@ -223,25 +248,23 @@
<label class="form-label max-w-56"> <label class="form-label max-w-56">
Ijin Usaha Ijin Usaha
</label> </label>
<div class="flex flex-wrap items-baseline w-full"> <div class="flex flex-wrap items-baseline w-full gap-1">
@if (isset($kjpp->ijin_usaha_id)) @if (isset($kjpp->ijin_usaha_id))
<div class="flex flex-row space-x-4 text-gray-600 font-medium text-sm gap-1"> @foreach (json_decode($kjpp->ijin_usaha_id, true) as $ijin_code)
@foreach (json_decode($kjpp->ijin_usaha_id, true) as $ijin_code) @php
@php $ijin_usaha = $ijin_usahas->firstWhere('code', $ijin_code);
$ijin_usaha = $ijin_usahas->firstWhere('code', $ijin_code); @endphp
@endphp @if ($ijin_usaha)
@if ($ijin_usaha) <div
<div class="flex flex-row space-x-4 text-white text-sm badge badge-dark dark-mode:badge dark-mode:text-gray-600">
class="flex flex-row space-x-4 text-white font-medium text-sm badge badge-dark dark-mode:badge dark-mode:text-gray-600"> {{ $ijin_usaha->name }}
{{ $ijin_usaha->name }} </div>
</div> @endif
@endif @endforeach
@endforeach
</div>
@else @else
<div class="flex flex-row space-x-4 text-white font-medium text-sm dark-mode:text-gray-600">No <div class="flex flex-row space-x-4 text-white text-sm dark-mode:text-gray-600">
business license -
selected.</div> </div>
@endif @endif
</div> </div>
</div> </div>
@@ -257,13 +280,13 @@
@endphp @endphp
@if ($jenis_aset) @if ($jenis_aset)
<span <span
class="flex flex-row space-x-4 text-white font-medium text-sm badge badge-dark dark-mode:badge dark-mode:text-gray-600"> class="flex flex-row space-x-4 text-white text-sm badge badge-dark dark-mode:badge dark-mode:text-gray-600">
{{ $jenis_aset->name }} {{ $jenis_aset->name }}
</span> </span>
@endif @endif
@endforeach @endforeach
@else @else
<span class="flex flex-row space-x-4 text-gray-600 font-medium text-sm dark-mode:text-gray-600"> <span class="flex flex-row space-x-4 text-gray-600 text-sm dark-mode:text-gray-600">
- -
</span> </span>
@endif @endif