package gcom.gui.micromedicao.leitura;
import gcom.gui.ActionServletException;
import gcom.gui.GcomAction;
import gcom.micromedicao.leitura.FiltroLeituraAnormalidade;
import gcom.micromedicao.leitura.LeituraAnormalidade;
import java.util.ArrayList;
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;
/**
* /**
* <p>
* <b>[UC0191]</b> Manter Anormalidade de Leitura
* </p>
* <p>
* Esta funcionalidade permite atualizar uma Anormalidade de Leitura
* </p>
*
* @author Thiago Ten�rio
* @since 31/10/2006
*/
public class ExibirManterAnormalidadeLeituraAction extends GcomAction {
/**
*
* @param actionMapping
* @param actionForm
* @param httpServletRequest
* @param httpServletResponse
* @return
*/
public ActionForward execute(ActionMapping actionMapping, ActionForm actionForm, HttpServletRequest httpServletRequest,
HttpServletResponse httpServletResponse) {
ActionForward retorno = actionMapping.findForward("exibirManterAnormalidadeLeitura");
HttpSession sessao = httpServletRequest.getSession(false);
/*
* Recupera o filtro passado pelo FiltrarResolucaoDiretoriaAction para
* ser efetuada pesquisa
*/
FiltroLeituraAnormalidade filtroLeituraAnormalidade = (FiltroLeituraAnormalidade) sessao.getAttribute("filtroLeituraAnormalidade");
/*
* Aciona o controle de pagina��o para que sejam pesquisados apenas os
* registros que aparecem na p�gina
*/
Collection colecaoAnormalidadeLeitura = new ArrayList();
if (filtroLeituraAnormalidade != null && !filtroLeituraAnormalidade.equals("")) {
Map resultado = controlarPaginacao(httpServletRequest, retorno, filtroLeituraAnormalidade, LeituraAnormalidade.class.getName());
colecaoAnormalidadeLeitura = (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 resolu��o de
* diretoria cadastrado para a pesquisa efetuada e em caso negativo e se
* atender a algumas condi��es seta o retorno para o
* ExibirAtualizarResolucaoDiretoriaAction, se n�o atender manda a
* cole��o pelo request para ser recuperado e exibido pelo jsp.
*/
if (colecaoAnormalidadeLeitura != null && !colecaoAnormalidadeLeitura.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 (colecaoAnormalidadeLeitura.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
* resolucao_diretoria_filtrar. Caso todas as condi��es sejam
* verdadeiras seta o retorno para o
* ExibirAtualizarResolucaoDiretoriaAction e em caso negativo
* manda a cole��o pelo request.
*/
if (httpServletRequest.getParameter("indicadorAtualizar") != null) {
retorno = actionMapping.findForward("exibirAtualizarAnormalidadeLeitura");
LeituraAnormalidade leituraAnormalidade = (LeituraAnormalidade) colecaoAnormalidadeLeitura.iterator().next();
sessao.setAttribute("leituraAnormalidade", leituraAnormalidade);
} else {
httpServletRequest.setAttribute("colecaoAnormalidadeLeitura", colecaoAnormalidadeLeitura);
}
} else {
httpServletRequest.setAttribute("colecaoAnormalidadeLeitura", colecaoAnormalidadeLeitura);
}
} else {
// Caso a pesquisa n�o retorne nenhum objeto comunica ao usu�rio;
throw new ActionServletException("atencao.pesquisa.nenhumresultado");
}
return retorno;
}
}