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