getRepositoryInstance()->scopeQuery(function ($query) use ($request) { foreach ($request->except($this->requestException) as $input => $value) { $query = $query->whereIn($input, array_map('trim', explode(',', $value))); } if($key = $request->input('search')){ $query = $query->where('name','like', '%'.$key.'%'); } if($category = $request->input('category')){ $query = $query->rightJoin('category_brands','brands.id','=','category_brands.brand_id') ->where('category_brands.category_id',$category); } if ($sort = $request->input('sort')) { $query = $query->orderBy($sort, $request->input('order') ?? 'asc'); } else { $query = $query->orderBy('id', 'asc'); } return $query; }); if (is_null($request->input('pagination')) || $request->input('pagination')) { $results = $query->paginate($request->input('limit') ?? 10); } else { $results = $query->get(); } return $this->getResourceCollection($results); } }