user) || !$this->user->can('debitur.view')) { //abort(403, 'Sorry! You are not allowed to view users.'); } // Retrieve data from the database $query = Permohonan::query()->where('status','=','preregister'); // Apply search filter if provided if ($request->has('search') && !empty($request->get('search'))) { $search = $request->get('search'); $query->where(function ($q) use ($search) { $q->where('nomor_registrasi', 'LIKE', '%' . $search . '%'); $q->orWhere('tanggal_permohonan', 'LIKE', '%' . $search . '%'); $q->orWhereRelation('user', 'name', 'LIKE', '%' . $search . '%'); $q->orWhereRelation('debiture', 'name', 'LIKE', '%' . $search . '%'); $q->orWhereRelation('tujuanPenilaian', 'name', 'LIKE', '%' . $search . '%'); $q->orWhereRelation('branch', 'name', 'LIKE', '%' . $search . '%'); $q->orWhere('status', 'LIKE', '%' . $search . '%'); }); } // Apply sorting if provided if ($request->has('sortOrder') && !empty($request->get('sortOrder'))) { $order = $request->get('sortOrder'); $column = $request->get('sortField'); $query->orderBy($column, $order); } // Get the total count of records $totalRecords = $query->count(); // Apply pagination if provided if ($request->has('page') && $request->has('size')) { $page = $request->get('page'); $size = $request->get('size'); $offset = ($page - 1) * $size; // Calculate the offset $query->skip($offset)->take($size); } // Get the filtered count of records $filteredRecords = $query->count(); // Get the data for the current page $data = $query->with(['user', 'debiture', 'branch', 'tujuanPenilaian'])->get(); // Calculate the page count $pageCount = ceil($totalRecords / $request->get('size')); // Calculate the current page number $currentPage = 0 + 1; // Return the response data as a JSON object return response()->json([ 'draw' => $request->get('draw'), 'recordsTotal' => $totalRecords, 'recordsFiltered' => $filteredRecords, 'pageCount' => $pageCount, 'page' => $currentPage, 'totalCount' => $totalRecords, 'data' => $data, ]); } public function edit($id) { return view('lpj::registrasi.edit', compact('id')); } public function setData(Request $request): JsonResponse { $data = array(); $datas = array(); if (request()->ajax()) { $id = $request->id; $datas = Permohonan::findOrFail($id); $data['status'] = 'success'; if ($datas) { $jenisPenilaians=null; $regions=null; $regions=Regions::pluck('name', 'id'); $jenisPenilaians=JenisPenilaian::pluck('name', 'id'); $data['regions'] = $regions; $data['jenisPenilaians'] = $jenisPenilaians; $data['datas'] = $datas; $data['message'] = 'data successfully found'; } else { $data['datas'] = null; $data['message'] = 'data not found'; } } else { $data['status'] = 'error'; $data['message'] = 'no ajax request'; } return response()->json($data); } public function update(Request $request, $id): JsonResponse { // init $data = array(); $dataku = array(); $tindakan = null; if (request()->ajax()) { $validator = RegistrasiController::rulesEditnya($request, $id); if ($validator['fails']) { $data['message'] = $validator['errors']; $data['status'] = 'error'; } else { try { $tindakan=$request->tindakan; $dataku = ['registrasi_by' => Auth::id(), 'registrasi_at' => now() ]; if($tindakan==0) { $dataku['jenis_penilaian_id'] =$request->jenis_penilaian; $dataku['region_id'] =$request->region; $dataku['status'] = 'registered'; } else { $dataku['registrasi_catatan'] =$request->catatan; $dataku['status'] = 'revisi'; } $data['dataku'] =$dataku; $modal = Permohonan::find($id); $modal->update($dataku); // $data['status'] = 'success'; $data['message'] = 'Regitrasi '.$modal->nomor_registrasi.' successfully'; } catch (Exception $e) { $data['status'] = 'error'; $data['message'] = 'Jenis Fasilitas Kredit updated failed.'; } } } else { $data['status'] = 'error'; $data['message'] = 'no ajax request'; } return response()->json($data)->with('success', 'Permohonan updated successfully'); } public function rulesEditnya($request, $id) { $tindakan=null; $jenis_penilaian=null; $validate_catatan=''; $tindakan=$request->tindakan; $jenis_penilaian=$request->jenis_penilaian; $validateIt = [ // 'name' diambil dari definisi parameter yang di kirim pada POST Data 'tindakan' => 'required', ]; $messageIt = [ 'tindakan.required' => 'Silahkan pilih Tindakan' ]; if($tindakan==0) { $validateIt['jenis_penilaian'] = ['required']; $messageIt ['jenis_penilaian.required']= 'Silahkan pilih Jenis Penilaian'; // INTERNAL if(1==$jenis_penilaian) { $validateIt['region'] = ['required']; $messageIt ['region.required']= 'Silahkan pilih Region'; } } elseif($tindakan==1) { $validateIt['catatan'] = ['required']; $messageIt ['catatan.required']= 'Silahkan isi Catatan'; } $validator = Validator::make($request->all(), $validateIt, $messageIt); $data['fails'] = $validator->fails(); $data['errors'] = $validator->errors(); return $data; } public function show($id) { return view('lpj::registrasi.show', compact('id')); } public function showData(Request $request): JsonResponse { $data = array(); $datas = array(); if (request()->ajax()) { $id = $request->id; $datas = Permohonan::findOrFail($id); $data['status'] = 'success'; if ($datas) { $data['datas'] = $datas; $data['message'] = 'data successfully found'; } else { $data['datas'] = null; $data['message'] = 'data not found'; } } else { $data['status'] = 'error'; $data['message'] = 'no ajax request'; } return response()->json($data); } }