ajax()) { $data = TicketModel::orderBy('created_at', 'desc')->select('*'); // Convert the Eloquent Collection to a regular PHP array $data->each(function ($item, $key) { $item->rowIndex = $key + 1; }); return DataTables::of($data) ->addIndexColumn() ->addColumn('title-post', function($row){ $text = '
' . $row->subject . '
Terakhir diperbarui pada ' . date_formatting($row->updated_at, 'timeago') . '
'; return $text; }) ->addColumn('siswa', function($row){ return User::where('id', $row->user_id)->first()->name; }) ->addColumn('action', function($row){ $view = route('ticket.view', ['id' => $row->id]); $delete = route('ticket.delete', ['id' => $row->id]); $btn = ' '; return $btn; }) ->addColumn('status', function($row){ if ($row->is_status == 1) { return 'Pending'; } elseif($row->is_status == 2) { return 'User Membalas'; } elseif($row->is_status == 3) { return 'Konselor Membalas'; } elseif($row->is_status == 4) { return 'Ditutup'; } }) ->addColumn('priority', function($row){ if ($row->is_priority == GlobalEnum::isTicketPriorityNormal) { return 'Normal'; } elseif($row->is_priority == GlobalEnum::isTicketPriorityMedium) { return 'Sedang'; } elseif($row->is_priority == GlobalEnum::isTicketPriorityHigh) { return 'Parah'; } }) ->rawColumns(['title-post','action','status','priority','siswa']) ->filter(function ($query) use ($request) { if ($request->has('search')) { $search = $request->get('search')['value']; $filterCategory = explode('|', $search); if($filterCategory[0] === 'status') { if(!empty($filterCategory[1])) { $query->where('is_status', '=', $filterCategory[1]); } else { $query->get(); } } elseif($filterCategory[0] === 'user') { if(!empty($filterCategory[1])) { $query->where('user_id', '=', User::where('name', 'like', "%$filterCategory[1]%")->first()->id); } else { $query->get(); } } } }) ->make(true); } $data = [ 'subtitle' => 'Riwayat Bimbingan & Konseling', ]; return view('admin.app.ticket.index', compact('data')); } public function cetak(Request $request) { $start_date = $request->start_date ?? Carbon::now()->subDays(30)->format('Y-m-d'); $end_date = $request->end_date ?? Carbon::now()->format('Y-m-d'); $case = $request->type ?? ''; $report = TicketModel::whereRaw('DATE(created_at) BETWEEN ? AND ?', [$start_date, $end_date])->where('subject', 'like', '%' . $case . '%', ); $periode = $start_date . ' s/d ' . $end_date; return view('admin.app.ticket.cetak', compact('report', 'periode')); } }