order_gizi/app/Http/Requests/KlasifikasiMenu/RequestKlasifikasiMenu.php

90 lines
3.1 KiB
PHP

<?php
namespace App\Http\Requests\KlasifikasiMenu;
use Illuminate\Contracts\Validation\Validator;
use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Http\Exceptions\HttpResponseException;
use Illuminate\Support\Facades\DB;
class RequestKlasifikasiMenu extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*/
public function authorize(): bool
{
return true;
}
/**
* Get the validation rules that apply to the request.
*
* @return array<string, \Illuminate\Contracts\Validation\ValidationRule|array<mixed>|string>
*/
public function rules(): array
{
return [
'data' => 'required|array|min:1',
'data.*.nama_kategori_diet' => 'required|string'
];
}
public function messages(){
return [
'data.array' => 'Format data harus berupa array',
'data.min' => 'Minimal harus ada satu data klasifikasi menu',
'data.*.nama_kategori_diet.required' => 'Nama Klasifikasi Menu wajib diisi',
'data.*.nama_kategori_diet.string' => 'Nama Kategori Soal harus berupa teks',
];
}
protected function failedValidation(Validator $validator){
throw new HttpResponseException(
response()->json([
'status' => 'VALIDATION_FAILED',
'message' => 'Validasi Gagal',
'errors' => $validator->errors()->messages(),
], 422)
);
}
public function withValidator($validator){
$validator->after(function ($validator){
$namaListAsli = collect($this->input('data'))->pluck('nama_kategori_diet')->filter();
$namaListLower = $namaListAsli->map(fn($n) => strtolower(trim($n)));
// ✅ Cek duplikat antar input user
$duplicates = $namaListLower->duplicates();
if ($duplicates->isNotEmpty()) {
foreach ($namaListAsli as $index => $nama) {
if ($duplicates->contains(strtolower(trim($nama)))) {
$validator->errors()->add("data.$index.nama_kategori_diet", "Nama '$nama' duplikat dalam input.");
}
}
}
$namaList = $namaListAsli->map(fn($n) => strtolower(trim($n)));
if($namaList->isEmpty()) return;
$exists = DB::connection('dbOrderGizi')
->table('public.kategori_diet')
->where('statusenabled', true)
->whereIn(DB::raw('LOWER(nama_kategori_diet)'), $namaList->toArray())
->selectRaw('LOWER(nama_kategori_diet) as nama')
->pluck('nama')
->toArray();
foreach ($namaListAsli as $index => $nama) {
$lowerNama = strtolower(trim($nama));
if(in_array($lowerNama, $exists)){
$validator->errors()->add("data.$index.nama_kategori_diet", "Nama '$nama' Sudah digunakan.");
}
}
});
}
}