package gcom.gui.atendimentopublico.registroatendimento; import gcom.atendimentopublico.registroatendimento.FiltroSolicitacaoTipo; import gcom.atendimentopublico.registroatendimento.SolicitacaoTipo; 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 07/11/2006 */ public class ExibirManterTipoSolicitacaoEspecificacaoAction 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("exibirManterTipoSolicitacaoEspecificacaoAction"); // Obt�m a inst�ncia da fachada // Fachada fachada = Fachada.getInstancia(); HttpSession sessao = httpServletRequest.getSession(false); // Limpa o atributo se o usu�rio voltou para o manter if (sessao.getAttribute("colecaoTipoSolicitacaoTela") != null) { sessao.removeAttribute("colecaoTipoSolicitacaoTela"); } // Recupera o filtro passado pelo // FiltrarTipoSolicitacaoEspecificacaoAction para // ser efetuada pesquisa FiltroSolicitacaoTipo filtroSolicitacaoTipo = (FiltroSolicitacaoTipo) sessao .getAttribute("filtroSolicitacaoTipo"); // Collection colecaoSolicitacaoTipoEspecificacaoAdicionar = // (Collection) sessao // .getAttribute("colecaoSolicitacaoTipoEspecificacao"); // Aciona o controle de pagina��o para que sejam pesquisados apenas // os registros que aparecem na p�gina Map resultado = controlarPaginacao(httpServletRequest, retorno, filtroSolicitacaoTipo, SolicitacaoTipo.class.getName()); Collection colecaoTipoSolicitacao = (Collection) resultado .get("colecaoRetorno"); retorno = (ActionForward) resultado.get("destinoActionForward"); sessao.removeAttribute("colecaoSolicitacaoTipoEspecificacao"); // 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 // ExibirAtualizarTipoSolicitacaoEspecificacaoAction, se n�o atender // manda a // cole��o pelo request para ser recuperado e exibido pelo jsp. if (colecaoTipoSolicitacao != null && !colecaoTipoSolicitacao.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 (colecaoTipoSolicitacao.size() == 1 && (httpServletRequest.getParameter("page.offset") == null || httpServletRequest .getParameter("page.offset").equals("1"))) { // Verifica se o usu�rio marcou o checkbox de atualizar no jsp // tipo_solicitacao_filtrar. Caso todas as condi��es sejam // verdadeiras seta o retorno para o // ExibirAtualizarTipoSolicitacaoEspecificacaoAction e em caso // negativo // manda a cole��o pelo request. if (httpServletRequest.getParameter("atualizar") != null) { retorno = actionMapping .findForward("atualizarTipoSolicitacaoEspecificacao"); SolicitacaoTipo solicitacaoTipo = (SolicitacaoTipo) colecaoTipoSolicitacao .iterator().next(); sessao.setAttribute("objetoSolicitacaoTipo", solicitacaoTipo); } else { httpServletRequest.setAttribute("colecaoTipoSolicitacao", colecaoTipoSolicitacao); } } else { httpServletRequest.setAttribute("colecaoTipoSolicitacao", colecaoTipoSolicitacao); } } else { // Nenhuma funcionalidade cadastrada throw new ActionServletException("atencao.pesquisa.nenhumresultado"); } return retorno; } }