2023-05-15 10:03:46 +00:00
|
|
|
<?php
|
|
|
|
|
2023-05-20 14:09:49 +00:00
|
|
|
namespace Modules\Cetaklabel\Http\Requests\Document;
|
2023-05-15 10:03:46 +00:00
|
|
|
|
2023-05-25 04:55:53 +00:00
|
|
|
use anlutro\LaravelSettings\Facades\Setting;
|
2023-05-15 10:03:46 +00:00
|
|
|
use Illuminate\Foundation\Http\FormRequest;
|
|
|
|
use Illuminate\Http\Exceptions\HttpResponseException;
|
|
|
|
use Illuminate\Validation\ValidationException;
|
|
|
|
use Illuminate\Validation\Validator;
|
2023-05-23 11:18:33 +00:00
|
|
|
use Modules\Cetaklabel\Entities\Directorat;
|
2023-05-25 04:55:53 +00:00
|
|
|
use Modules\Cetaklabel\Entities\Document;
|
|
|
|
use Modules\Cetaklabel\Entities\DocumentDetail;
|
2023-05-23 11:18:33 +00:00
|
|
|
use Modules\Cetaklabel\Entities\Job;
|
|
|
|
use Modules\Cetaklabel\Entities\SubDirectorat;
|
|
|
|
use Modules\Cetaklabel\Entities\SubJob;
|
|
|
|
use Modules\Cetaklabel\Entities\SubSubJob;
|
2023-05-15 10:03:46 +00:00
|
|
|
use Symfony\Component\HttpFoundation\JsonResponse;
|
|
|
|
|
|
|
|
class StoreDocumentRequest extends FormRequest
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Determine if the user is authorized to make this request.
|
|
|
|
*/
|
2023-05-25 04:55:53 +00:00
|
|
|
public function authorize(): bool
|
2023-05-15 10:03:46 +00:00
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the validation rules that apply to the request.
|
|
|
|
*
|
|
|
|
* @return array<string, \Illuminate\Contracts\Validation\Rule|array|string>
|
|
|
|
*/
|
2023-05-25 04:55:53 +00:00
|
|
|
public function rules(): array
|
2023-05-15 10:03:46 +00:00
|
|
|
{
|
|
|
|
return [
|
2023-05-25 01:53:06 +00:00
|
|
|
'kode' => 'required|string',
|
|
|
|
'kode_dus' => 'required|string',
|
|
|
|
'kode_odner' => 'required|string',
|
2023-05-15 10:03:46 +00:00
|
|
|
'directorat_id' => 'required|integer|exists:directorats,id',
|
|
|
|
'sub_directorat_id' => 'required|integer|exists:sub_directorats,id',
|
|
|
|
'job_id' => 'required|integer|exists:jobs,id',
|
|
|
|
'sub_job_id' => 'required|integer|exists:sub_jobs,id',
|
|
|
|
'sub_sub_job_id' => 'required|integer|exists:sub_sub_jobs,id',
|
2023-05-25 01:53:06 +00:00
|
|
|
'sequence' => 'nullable|integer|min:1|max:5',
|
|
|
|
'sequence_dus' => 'nullable|integer|min:1|max:5',
|
|
|
|
'sequence_odner' => 'nullable|integer|min:1|max:5',
|
2023-05-15 10:03:46 +00:00
|
|
|
'status' => 'nullable|integer',
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Configure the validator instance.
|
|
|
|
*/
|
2023-05-25 04:55:53 +00:00
|
|
|
public function withValidator(Validator $validator): void
|
2023-05-15 10:03:46 +00:00
|
|
|
{
|
2023-05-15 14:14:52 +00:00
|
|
|
$validator->after(function (Validator $validator) {
|
|
|
|
if ($validator->errors()->any()) {
|
|
|
|
$error = json_decode($validator->errors()->toJson(), true);
|
2023-05-15 10:03:46 +00:00
|
|
|
foreach ($error as $key => $value) {
|
2023-05-15 14:14:52 +00:00
|
|
|
flash($value[0]);
|
2023-05-15 10:03:46 +00:00
|
|
|
}
|
|
|
|
|
2023-05-15 14:14:52 +00:00
|
|
|
return redirect()->route('document.index')->with('error', 'Document created failed.');
|
2023-05-15 10:03:46 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-05-25 04:55:53 +00:00
|
|
|
protected function failedValidation(Validator|\Illuminate\Contracts\Validation\Validator $validator): JsonResponse
|
2023-05-15 10:03:46 +00:00
|
|
|
{
|
2023-05-15 14:14:52 +00:00
|
|
|
$errors = (new ValidationException($validator))->errors();
|
2023-05-15 10:03:46 +00:00
|
|
|
|
2023-05-15 14:14:52 +00:00
|
|
|
throw new HttpResponseException(response()->json([
|
2023-05-15 10:03:46 +00:00
|
|
|
'success' => false,
|
|
|
|
'errors' => $errors,
|
|
|
|
'messages' => 'Document created failed.'
|
|
|
|
], JsonResponse::HTTP_UNPROCESSABLE_ENTITY));
|
|
|
|
}
|
2023-05-23 11:18:33 +00:00
|
|
|
|
2023-05-25 04:55:53 +00:00
|
|
|
protected function prepareForValidation(): void
|
2023-05-23 11:18:33 +00:00
|
|
|
{
|
|
|
|
|
|
|
|
$directorat = Directorat::find($this->directorat_id);
|
|
|
|
$sub_directorat = SubDirectorat::find($this->sub_directorat_id);
|
|
|
|
$job = Job::find($this->job_id);
|
|
|
|
$sub_job = SubJob::find($this->sub_job_id);
|
|
|
|
$sub_sub_job = SubSubJob::find($this->sub_sub_job_id);
|
|
|
|
|
2023-05-25 04:55:53 +00:00
|
|
|
$prefix = $directorat->kode . $sub_directorat->kode . $job->kode . $sub_job->kode . $sub_sub_job->kode;
|
|
|
|
$sequence_dus = 1;
|
|
|
|
$sequence_odner = 1;
|
2023-05-25 08:07:59 +00:00
|
|
|
$sum_halaman_document = 0;
|
2023-05-25 04:55:53 +00:00
|
|
|
|
|
|
|
|
|
|
|
$max_sequence_dus = Document::where('kode_dus', substr($prefix, 0, 6))->max('sequence_dus');
|
2023-05-25 08:07:59 +00:00
|
|
|
$max_sequence_odner = Document::where(['kode_odner' => substr($prefix, 0, 8),'sequence_dus' => $max_sequence_dus])->max('sequence_odner');
|
2023-05-25 04:55:53 +00:00
|
|
|
|
|
|
|
if ($max_sequence_odner == 5) {
|
|
|
|
if ($max_sequence_dus < 5) {
|
|
|
|
$sequence_dus = $max_sequence_dus + 1;
|
|
|
|
} else {
|
|
|
|
$sequence_dus = $max_sequence_dus;
|
|
|
|
}
|
|
|
|
} else {
|
2023-05-25 08:07:59 +00:00
|
|
|
$sum_halaman_document = $this->sumHalaman($prefix,$this->sequence,$sequence_dus);
|
|
|
|
|
|
|
|
if($sum_halaman_document < Setting::get('maximal_halaman_per_dus')){
|
|
|
|
if(($sum_halaman_document + $this->jumlah_halaman) >= Setting::get('maximal_halaman_per_dus')){
|
2023-05-26 02:31:37 +00:00
|
|
|
$sequence_odner += 1;
|
2023-05-25 08:07:59 +00:00
|
|
|
} else {
|
|
|
|
$sequence_odner = $this->sequence;
|
|
|
|
}
|
2023-05-25 04:55:53 +00:00
|
|
|
} else {
|
2023-05-25 08:07:59 +00:00
|
|
|
for($i = 1; $i <= Setting::get('maximal_odner_per_dus'); $i++){
|
|
|
|
$sum_halaman_document = $this->sumHalaman($prefix,$i,$sequence_dus);
|
|
|
|
if($sum_halaman_document < Setting::get('maximal_halaman_per_odner')){
|
|
|
|
if(($sum_halaman_document + $this->jumlah_halaman) >= Setting::get('maximal_halaman_per_odner')){
|
2023-05-26 02:31:37 +00:00
|
|
|
$sequence_odner = $i + 1;
|
2023-05-25 08:07:59 +00:00
|
|
|
break;
|
|
|
|
} else {
|
2023-05-26 02:31:37 +00:00
|
|
|
$sequence_odner = $this->sequence;
|
2023-05-25 08:07:59 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-05-25 04:55:53 +00:00
|
|
|
}
|
2023-05-25 08:07:59 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-25 04:55:53 +00:00
|
|
|
}
|
2023-05-23 11:18:33 +00:00
|
|
|
|
|
|
|
$this->merge([
|
2023-05-25 04:55:53 +00:00
|
|
|
'kode' => $prefix,
|
|
|
|
'kode_dus' => substr($prefix, 0, 6),
|
|
|
|
'kode_odner' => substr($prefix, 0, 8),
|
|
|
|
'sequence_dus' => $sequence_dus,
|
|
|
|
'sequence_odner' => $sequence_odner
|
2023-05-23 11:18:33 +00:00
|
|
|
]);
|
|
|
|
}
|
2023-05-25 08:07:59 +00:00
|
|
|
|
|
|
|
private function sumHalaman($prefix,$id, $dus = 1){
|
|
|
|
$document = Document::where(['kode_odner' => substr($prefix, 0, 8), 'sequence_odner' => $id, 'sequence_dus' => $dus])->first();
|
|
|
|
|
|
|
|
if($document == null){
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
$sum_halaman_document = DocumentDetail::where('document_id', $document->id)->sum('jumlah_halaman');
|
|
|
|
return $sum_halaman_document;
|
|
|
|
}
|
2023-05-15 10:03:46 +00:00
|
|
|
}
|