package gcom.gui.cadastro.imovel; import gcom.cadastro.imovel.FiltroImovelSituacao; import gcom.cadastro.imovel.ImovelSituacao; import gcom.gui.ActionServletException; import gcom.gui.GcomAction; import java.util.Collection; import java.util.Map; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import org.apache.struts.action.ActionForm; import org.apache.struts.action.ActionForward; import org.apache.struts.action.ActionMapping; /** * Descri��o da classe * * @author R�mulo Aur�lio * @date 04/04/2006 */ public class ExibirManterImovelSituacaoAction extends GcomAction { /** * < <Descri��o do m�todo>> * * @param actionMapping * Descri��o do par�metro * @param actionForm * Descri��o do par�metro * @param httpServletRequest * Descri��o do par�metro * @param httpServletResponse * Descri��o do par�metro * @return Descri��o do retorno */ public ActionForward execute(ActionMapping actionMapping, ActionForm actionForm, HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) { ActionForward retorno = actionMapping .findForward("manterImovelSituacao"); HttpSession sessao = httpServletRequest.getSession(false); // Recupera o filtro passado pelo FiltrarImovelSituacaoAction para // ser efetuada pesquisa FiltroImovelSituacao filtroImovelSituacao = (FiltroImovelSituacao) sessao .getAttribute("filtroImovelSituacao"); // Aciona o controle de pagina��o para que sejam pesquisados apenas // os registros que aparecem na p�gina Map resultado = controlarPaginacao(httpServletRequest, retorno, filtroImovelSituacao, ImovelSituacao.class.getName()); Collection colecaoImovelSituacao = (Collection) resultado .get("colecaoRetorno"); retorno = (ActionForward) resultado.get("destinoActionForward"); // Verifica se a cole��o retornada pela pesquisa � nula, em caso // afirmativo comunica ao usu�rio que n�o existe nenhuma fuuncionalidade // cadastrada // para a pesquisa efetuada e em caso negativo e se // atender a algumas condi��es seta o retorno para o // ExibirAtualizarFuncionalidadeAction, se n�o atender manda a // cole��o pelo request para ser recuperado e exibido pelo jsp. if (colecaoImovelSituacao != null && !colecaoImovelSituacao.isEmpty()) { // Verifica se a cole��o cont�m apenas um objeto, se est� retornando // da pagina��o (devido ao esquema de pagina��o de 10 em 10 faz uma // nova busca), evitando, assim, que caso haja 11 elementos no // retorno da pesquisa e o usu�rio selecione o link para ir para a // segunda p�gina ele n�o v� para tela de atualizar. if (colecaoImovelSituacao.size() == 1 && (httpServletRequest.getParameter("page.offset") == null || httpServletRequest .getParameter("page.offset").equals("1"))) { } else { httpServletRequest.setAttribute("colecaoImovelSituacao", colecaoImovelSituacao); } } else { // Nenhuma funcionalidade cadastrada throw new ActionServletException("atencao.pesquisa.nenhumresultado"); } return retorno; } }