checkPermission('settings-manage'); $this->checkPermission('users-manage'); $listDetails = [ 'order' => $request->get('order', 'desc'), 'event' => $request->get('event', ''), 'sort' => $request->get('sort', 'created_at'), 'date_from' => $request->get('date_from', ''), 'date_to' => $request->get('date_to', ''), 'user' => $request->get('user', ''), 'ip' => $request->get('ip', ''), ]; $query = Activity::query() ->with([ 'entity' => function ($query) { $query->withTrashed(); }, 'user', ]) ->orderBy($listDetails['sort'], $listDetails['order']); if ($listDetails['event']) { $query->where('type', '=', $listDetails['event']); } if ($listDetails['user']) { $query->where('user_id', '=', $listDetails['user']); } if ($listDetails['date_from']) { $query->where('created_at', '>=', $listDetails['date_from']); } if ($listDetails['date_to']) { $query->where('created_at', '<=', $listDetails['date_to']); } if ($listDetails['ip']) { $query->where('ip', 'like', $listDetails['ip'] . "%"); } $activities = $query->paginate(100); $activities->appends($listDetails); $types = DB::table('activities')->select('type')->distinct()->pluck('type'); $this->setPageTitle(trans('settings.audit')); return view('settings.audit', [ 'activities' => $activities, 'listDetails' => $listDetails, 'activityTypes' => $types, ]); } }