/** * Metodo para filtrar Ongs por POST, * @param categoriaOng -> id da categoria a ser usada no filtro * @param nome -> nome a ser usado no filtro * @param cidade_id -> id da cidade a ser usado no filtro */ public function postFiltrarongs() { $categoriaOng = Request::get('filtro_categoria'); $nome = Request::get('nome'); $cidade_id = Request::get('filtro_cidade'); $ongs = new Collection(); //Filtrando resultados pelas categorias if ($categoriaOng && $categoriaOng != "null") { $ongsByCategoria = CategoriaOng::findOrFail($categoriaOng)->ongs; $ongs = $ongs->merge($ongsByCategoria); } //Fitrando resultados com base no nome if ($nome) { $ongsByNome = Ong::where('nome', 'ILIKE', "%" . $nome . "%")->get(); //Se ja tiver filtrado por categoria, entao interseccionar os //resultados para maior relevancia if (count($ongs)) { $ongs = $ongs->intersect($ongsByNome); } else { $ongs = $ongs->merge($ongsByNome); } } //Filtrando resultados por Cidade if ($cidade_id) { $ongsByCidade = Cidade::findOrFail($cidade_id)->ongs; //Se ja tiver filtrado, entao interseccionar os //resultados para maior relevancia if (count($ongs)) { $ongs = $ongs->intersect($ongsByCidade); } else { $ongs = $ongs->merge($ongsByCidade); } } $cidades = Ong::getCidadesComOngs(); $cidadesArray = array(0 => 'Cidade'); foreach ($cidades as $cidade) { $cidadesArray[$cidade->id] = $cidade->nome; } $cidades = $cidadesArray; $categorias = Ong::getCategoriasComOngs(); $categoriasArray = array(0 => 'Categoria'); foreach ($categorias as $categoria) { $categoriasArray[$categoria->id] = $categoria->nomeTraduzido; } $categorias = $categoriasArray; //Se nao vier nenhum filtro, mostrar todas as ongs if (!$nome && (!$categoriaOng || $categoriaOng == "null") && !$cidade_id) { $ongs = Ong::all(); } return view('cuidar.ongs', compact('ongs', 'categorias', 'cidades')); }
/** * Mostra todas as ongs e um filtro * * @param int $id * @return Response */ public function ongs() { $ongs = Ong::all(); $categorias = Ong::getCategoriasComOngs(); $cidades = Ong::getCidadesComOngs(); //Arrumando array de cidades para select $cidadesArray = array(0 => 'Cidade'); foreach ($cidades as $cidade) { $cidadesArray[$cidade->id] = $cidade->nome; } $cidades = $cidadesArray; $categoriasArray = array(0 => 'Categoria'); foreach ($categorias as $categoria) { $categoriasArray[$categoria->id] = $categoria->nome; } $categorias = $categoriasArray; return view('cuidar.ongs', compact('ongs', 'categorias', 'cidades')); }