Cetaklabel/Http/Requests/SpecialCode/UpdateSpecialCodeRequest.php

82 lines
2.7 KiB
PHP

<?php
namespace Modules\Cetaklabel\Http\Requests\SpecialCode;
use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Http\Exceptions\HttpResponseException;
use Illuminate\Http\JsonResponse;
use Illuminate\Validation\ValidationException;
use Illuminate\Validation\Validator;
class UpdateSpecialCodeRequest 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\Rule|array|string>
*/
public function rules()
: array
{
return [
'kode' => 'required|string|max:2|min:2|unique:special_codes,kode,' . $this->special_code->id,
'name' => 'required|string|max:50',
'description' => 'nullable|string|max:255',
'status' => 'nullable|integer',
'approved_at' => 'nullable|date',
'approved_by' => 'nullable|integer'
];
}
/**
* Configure the validator instance.
*/
public function withValidator(Validator $validator)
: void
{
$validator->after(function (Validator $validator) {
if ($validator->errors()->any()) {
$error = json_decode($validator->errors()->toJson(), true);
foreach ($error as $key => $value) {
flash($value[0]);
}
return redirect()->route('special-code.index')->with('error', 'Special Code updated failed.');
}
});
}
protected function failedValidation(Validator|\Illuminate\Contracts\Validation\Validator $validator)
: JsonResponse
{
$errors = (new ValidationException($validator))->errors();
throw new HttpResponseException(response()->json([
'success' => false,
'errors' => $errors,
'messages' => 'Special Code updated failed.'
], JsonResponse::HTTP_UNPROCESSABLE_ENTITY));
}
protected function prepareForValidation()
{
if(isset($this->status) && $this->status == 1) {
if (isset($this->approval) && $this->approval == 1) {
$this->merge([
'approved_at' => now(),
'approved_by' => auth()->user()->id,
]);
}
}
}
}