user) || !$this->user->can('debitur.view')) { // abort(403, 'Sorry! You are not allowed to view users.'); } /* // Tentukan status berdasarkan otorisator $status = match ($otorisator) { 'Pelaporan' => 'proses-laporan', 'Pembayaran' => 'proses', 'Pembatalan' => 'batal', 'SLA' => 'freeze', default => '', }; */ $query = Permohonan::query()->whereIn('status_bayar', ['sudah_bayar']); /* // Pencarian berdasarkan parameter search 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 . '%'); }); } */ // Filter berdasarkan region user yang login // $query->whereHas('region.teams.teamsUsers', function ($q) { // $q->where('user_id', Auth::id()); // }); // Sorting berdasarkan sortField dan sortOrder if ($request->has('sortOrder') && !empty($request->get('sortOrder'))) { $order = $request->get('sortOrder'); $column = $request->get('sortField'); $query->orderBy($column, $order); } // Hitung total records $totalRecords = $query->count(); // Pagination (default page size 10) $size = $request->get('size', 10); if ($size == 0) { $size = 10; } if ($request->has('page') && $request->has('size')) { $page = $request->get('page', 1); $offset = ($page - 1) * $size; $query->skip($offset)->take($size); } // Filtered records $filteredRecords = $query->count(); // Ambil data dengan relasi $data = $query->with(['user', 'debiture', 'branch', 'tujuanPenilaian', 'region.teams.teamsUsers'])->get(); // Hitung jumlah halaman $pageCount = ceil($totalRecords / $size); // Ambil current page $currentPage = max(1, $request->get('page', 1)); // Return JSON response return response()->json([ 'draw' => $request->get('draw'), 'recordsTotal' => $totalRecords, 'recordsFiltered' => $filteredRecords, 'pageCount' => $pageCount, 'page' => $currentPage, 'totalCount' => $totalRecords, 'data' => $data, ]); } public function update(Request $request, $id) : JsonResponse { // init $data = []; $dataku = []; $tindakan = null; if (request()->ajax()) { try { $dataku = [ 'approve_bayar_by' => Auth::id(), 'approve_bayar_at' => now(), ]; if ($request->keterangan) { $dataku['approve_keterangan_bayar'] = $request->keterangan; } $data['dataku'] = $dataku; $modal = Permohonan::find($id); $modal->update($dataku); // $data['status'] = 'success'; $data['message'] = ['Otorisasi' . $modal->nomor_registrasi . 'berhasil di lakukan']; } catch (Exception $e) { $data['status'] = 'error'; $data['message'] = ['Otorisasi gagal di lakukan.']; } } return response()->json($data); } }