- Menambahkan kolom `parent_id` pada tabel `branches` dengan migrasi baru. - Update model `Branch`: - Menambahkan relasi `parent()` untuk mendapatkan cabang induk. - Menambahkan relasi `children()` untuk mendapatkan anak cabang. - Update `BranchController`: - Menampilkan daftar cabang induk saat membuat atau mengedit cabang. - Cek validasi agar cabang tidak bisa menjadi induk dirinya sendiri. - Tambahkan larangan hapus cabang jika memiliki anak cabang, baik untuk hapus tunggal maupun multiple. - Update validation rules pada `BranchRequest` untuk memastikan validitas `parent_id`. - Update tampilan: - Formulir pembuatan/edit cabang: Menampilkan dropdown untuk memilih cabang induk. - Daftar cabang: Menampilkan kolom untuk cabang induk. - Tambahkan test unit: - Validasi relasi parent-child pada penyimpanan dan pembaruan cabang. - Melarang penghapusan cabang yang memiliki anak. - Memastikan perilaku relasi parent-child sesuai ekspektasi. Signed-off-by: Daeng Deni Mardaeni <ddeni05@gmail.com>
65 lines
2.0 KiB
PHP
65 lines
2.0 KiB
PHP
<?php
|
|
|
|
namespace Modules\Basicdata\Http\Requests;
|
|
|
|
use Illuminate\Foundation\Http\FormRequest;
|
|
use Illuminate\Validation\Rule;
|
|
|
|
class BranchRequest extends FormRequest
|
|
{
|
|
/**
|
|
* Get the validation rules that apply to the request.
|
|
*/
|
|
public function rules()
|
|
: array
|
|
{
|
|
$rules = [
|
|
'name' => 'required|string|max:255',
|
|
'parent_id' => [
|
|
'nullable',
|
|
'exists:branches,id',
|
|
function ($attribute, $value, $fail) {
|
|
if ($value == $this->route('branch')) {
|
|
$fail('Cabang tidak dapat menjadi induk dari dirinya sendiri.');
|
|
}
|
|
},
|
|
],
|
|
'status' => 'nullable|boolean',
|
|
'authorized_at' => 'nullable|datetime',
|
|
'authorized_status' => 'nullable|string|max:1',
|
|
'authorized_by' => 'nullable|exists:users,id',
|
|
];
|
|
|
|
if ($this->method() == 'PUT') {
|
|
$rules['code'] = [
|
|
'required',
|
|
'string',
|
|
'max:10',
|
|
Rule::unique('branches')->ignore($this->id)->where(function ($query) {
|
|
return $query->whereNull('deleted_at');
|
|
}),
|
|
];
|
|
} else {
|
|
$rules['code'] = [
|
|
'required',
|
|
'string',
|
|
'max:10',
|
|
Rule::unique('branches')->where(function ($query) {
|
|
return $query->whereNull('deleted_at');
|
|
}),
|
|
];
|
|
}
|
|
|
|
return $rules;
|
|
}
|
|
|
|
/**
|
|
* Determine if the user is authorized to make this request.
|
|
*/
|
|
public function authorize()
|
|
: bool
|
|
{
|
|
return true;
|
|
}
|
|
}
|