package gcom.gui.atendimentopublico.ordemservico;
import gcom.atendimentopublico.ordemservico.Equipe;
import gcom.fachada.Fachada;
import gcom.gui.ActionServletException;
import gcom.gui.GcomAction;
import java.util.Collection;
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;
/**
*
* Permite exibir uma lista com as resolu��es de diretoria retornadas do
* FiltrarResolucaoDiretoriaAction ou ir para o
* ExibirAtualizarResolucaoDiretoriaAction
*
* @author Rafael Corr�a
* @since 31/03/2006
*/
public class ExibirManterEquipeAction extends GcomAction {
/**
*
* @param actionMapping
* @param actionForm
* @param httpServletRequest
* @param httpServletResponse
* @return
*/
public ActionForward execute(ActionMapping actionMapping,
ActionForm actionForm, HttpServletRequest httpServletRequest,
HttpServletResponse httpServletResponse) {
// Seta o mapeamento de retorno
ActionForward retorno = actionMapping.findForward("exibirManterEquipe");
// Obt�m a inst�ncia da fachada
Fachada fachada = Fachada.getInstancia();
HttpSession sessao = httpServletRequest.getSession(false);
sessao.removeAttribute("equipeAtualizar");
// Recupera os par�metros da sess�o para ser efetuada a pesquisa
String idEquipe = (String) sessao.getAttribute("idEquipe");
String nome = (String) sessao.getAttribute("nome");
String placa = (String) sessao.getAttribute("placa");
String cargaTrabalho = (String) sessao.getAttribute("cargaTrabalho");
String idUnidade = (String) sessao.getAttribute("idUnidade");
String idFuncionario = (String) sessao.getAttribute("idFuncionario");
String idPerfilServico = (String) sessao
.getAttribute("idPerfilServico");
String indicadorUso = (String) sessao.getAttribute("indicadorUso");
String indicadorProgramacaoAutomatica = (String) sessao.getAttribute("indicadorProgramacaoAutomatica");
String tipoPesquisa = (String) sessao.getAttribute("tipoPesquisa");
String codigoDdd = (String) sessao.getAttribute("codigoDdd");
String numeroTelefone = (String) sessao.getAttribute("numeroTelefone");
String numeroImei = (String) sessao.getAttribute("numeroImei");
String equipamentosEspeciasId = (String) sessao.getAttribute("equipamentosEspeciasId");
String cdUsuarioRespExcServico = (String) sessao.getAttribute("cdUsuarioRespExcServico");
// Aciona o controle de pagina��o para que sejam pesquisados apenas
// os registros que aparecem na p�gina
Integer totalRegistros = fachada.pesquisarEquipesCount(idEquipe, nome,
placa, cargaTrabalho, codigoDdd, numeroTelefone, numeroImei, idUnidade, idFuncionario,
idPerfilServico, indicadorUso, tipoPesquisa,equipamentosEspeciasId, cdUsuarioRespExcServico, indicadorProgramacaoAutomatica);
retorno = this.controlarPaginacao(httpServletRequest, retorno,
totalRegistros);
Collection colecaoEquipes = fachada.pesquisarEquipes(idEquipe, nome,
placa, cargaTrabalho, codigoDdd, numeroTelefone, numeroImei, idUnidade, idFuncionario,
idPerfilServico, indicadorUso, tipoPesquisa, (Integer) httpServletRequest
.getAttribute("numeroPaginasPesquisa"),equipamentosEspeciasId, cdUsuarioRespExcServico, indicadorProgramacaoAutomatica);
// Verifica se a cole��o retornada pela pesquisa � nula, em caso
// afirmativo comunica ao usu�rio que n�o existe nenhuma equipe
// cadastrada para a pesquisa efetuada e em caso negativo e se
// atender a algumas condi��es seta o retorno para o
// ExibirAtualizarEquipeAction, se n�o atender manda a
// cole��o pelo request para ser recuperado e exibido pelo jsp.
if (colecaoEquipes != null && !colecaoEquipes.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 (colecaoEquipes.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
// equipe_filtrar. Caso todas as condi��es sejam
// verdadeiras seta o retorno para o
// ExibirAtualizarEquipeAction e em caso negativo
// manda a cole��o pelo request.
if (sessao.getAttribute("atualizar") != null) {
retorno = actionMapping
.findForward("exibirAtualizarEquipe");
Equipe equipe = (Equipe) colecaoEquipes.iterator().next();
sessao.setAttribute("equipe", equipe);
} else {
httpServletRequest.setAttribute("colecaoEquipes",
colecaoEquipes);
}
} else {
httpServletRequest.setAttribute("colecaoEquipes",
colecaoEquipes);
}
} else {
// Caso a pesquisa n�o retorne nenhum objeto comunica ao usu�rio;
throw new ActionServletException("atencao.pesquisa.nenhumresultado");
}
return retorno;
}
}