request = \request(); } else { $this->request = $request; } } /** * Apply criteria in query repository * * @param string $model * @param RepositoryInterface $repository * * @return mixed */ public function apply($model, RepositoryInterface $repository) { if ($title = $this->request->get('title')) { $model = $model->where('title', 'like', "%{$title}%"); } if (($status = $this->request->get('status', false)) !== false) { $model = $model->where('status', '=', $status); } if ($category_id = $this->request->get('category_id')) { $ids = Category::sonGroup($category_id); $ids[] = $category_id; $model = $model->whereIn('category_id', $ids); } $model = $model->orderByDesc('sort')->orderByDesc('published_at')->orderByDesc('id'); return $model; } }