package gcom.relatorio.faturamento.conta; import gcom.batch.Relatorio; import gcom.cadastro.cliente.EsferaPoder; import gcom.cadastro.empresa.Empresa; import gcom.cadastro.sistemaparametro.SistemaParametro; import gcom.fachada.Fachada; import gcom.faturamento.bean.MapaControleContaRelatorioHelper; import gcom.gui.ActionServletException; import gcom.relatorio.ConstantesRelatorios; import gcom.relatorio.RelatorioDataSource; import gcom.relatorio.RelatorioVazioException; import gcom.seguranca.acesso.usuario.Usuario; import gcom.tarefa.TarefaException; import gcom.tarefa.TarefaRelatorio; import gcom.util.ControladorException; import gcom.util.Util; import gcom.util.agendadortarefas.AgendadorTarefas; import java.util.ArrayList; import java.util.Collection; import java.util.HashMap; import java.util.Iterator; import java.util.Map; /** * [UC] * @author Flavio Cordeiro * @date 14/02/2007 */ public class RelatorioResumoContaLocalidade extends TarefaRelatorio { private static final long serialVersionUID = 1L; public RelatorioResumoContaLocalidade(Usuario usuario) { super(usuario, ConstantesRelatorios.RELATORIO_RESUMO_CONTA_LOCALIDADE); } private Collection inicializarBeanRelatorio( Collection colecaoResumoContaLocalidadeConta) { Collection retorno = new ArrayList(); Integer qtdTotalPublico =0; Integer idLocalidadeAnterior = 0; Integer qtdTotalFirma = 0; Integer qtdTotalCorreios = 0; Integer qtdTotalContas = 0; Integer qtdTotalMacro = 0; Integer qtdTotalGeralFirma = 0; Integer qtdTotalGeralCorreio = 0; Integer qtdTotalGeralPublico = 0; Integer qtdTotalGeral = 0; boolean primeirVez = true; if(colecaoResumoContaLocalidadeConta != null && !colecaoResumoContaLocalidadeConta.isEmpty()){ Iterator iter = colecaoResumoContaLocalidadeConta.iterator(); while (iter.hasNext()) { MapaControleContaRelatorioHelper mapaControleContaRelatorioHelper = (MapaControleContaRelatorioHelper) iter.next(); qtdTotalContas = 0; qtdTotalMacro = 0; if(mapaControleContaRelatorioHelper.getIdLocalidade() != null){ Integer idLocalidadeAtual = new Integer(mapaControleContaRelatorioHelper.getIdLocalidade()); if(primeirVez){ primeirVez = false; idLocalidadeAnterior = idLocalidadeAtual; } //la�o para somar as contas while(idLocalidadeAtual.equals(idLocalidadeAnterior) && iter.hasNext()){ if (idLocalidadeAtual.equals(idLocalidadeAnterior) && mapaControleContaRelatorioHelper.getIdEsferaPoder() != null && !mapaControleContaRelatorioHelper.getIdEsferaPoder().equals(new Integer(EsferaPoder.PARTICULAR+""))){ idLocalidadeAnterior = idLocalidadeAtual; qtdTotalPublico = qtdTotalPublico + mapaControleContaRelatorioHelper.getQtdeContas(); qtdTotalGeralPublico = qtdTotalGeralPublico + mapaControleContaRelatorioHelper.getQtdeContas(); } if(mapaControleContaRelatorioHelper.getIdEsferaPoder() == null){ qtdTotalFirma = mapaControleContaRelatorioHelper.getQtdeContas(); qtdTotalGeralFirma = qtdTotalGeralFirma + mapaControleContaRelatorioHelper.getQtdeContas(); }else if(mapaControleContaRelatorioHelper.getIdEsferaPoder().equals(new Integer(EsferaPoder.PARTICULAR+""))){ qtdTotalCorreios = mapaControleContaRelatorioHelper.getQtdeContas(); qtdTotalGeralCorreio = qtdTotalGeralCorreio + mapaControleContaRelatorioHelper.getQtdeContas(); } qtdTotalMacro = qtdTotalMacro + mapaControleContaRelatorioHelper.getQtdTotalMacro(); qtdTotalContas = qtdTotalContas + mapaControleContaRelatorioHelper.getQtdeContas(); mapaControleContaRelatorioHelper = (MapaControleContaRelatorioHelper) iter.next(); idLocalidadeAtual = new Integer(mapaControleContaRelatorioHelper.getIdLocalidade()); } if (!iter.hasNext()) { if (!idLocalidadeAtual.equals(idLocalidadeAnterior)){ qtdTotalContas = 0; qtdTotalMacro = 0; } if (mapaControleContaRelatorioHelper.getIdEsferaPoder() != null && !mapaControleContaRelatorioHelper.getIdEsferaPoder().equals(new Integer(EsferaPoder.PARTICULAR+""))){ qtdTotalPublico = qtdTotalPublico + mapaControleContaRelatorioHelper.getQtdeContas(); qtdTotalGeralPublico = qtdTotalGeralPublico + mapaControleContaRelatorioHelper.getQtdeContas(); } if(mapaControleContaRelatorioHelper.getIdEsferaPoder() == null){ qtdTotalFirma = mapaControleContaRelatorioHelper.getQtdeContas(); qtdTotalGeralFirma = qtdTotalGeralFirma + mapaControleContaRelatorioHelper.getQtdeContas(); }else if(mapaControleContaRelatorioHelper.getIdEsferaPoder().equals(new Integer(EsferaPoder.PARTICULAR+""))){ qtdTotalCorreios = mapaControleContaRelatorioHelper.getQtdeContas(); qtdTotalGeralCorreio = qtdTotalGeralCorreio + mapaControleContaRelatorioHelper.getQtdeContas(); } } qtdTotalContas = qtdTotalContas + mapaControleContaRelatorioHelper.getQtdeContas(); qtdTotalGeral = qtdTotalGeral + qtdTotalContas; RelatorioMapaControleContaBean relatorioResumoContaLocalidadeBean = new RelatorioMapaControleContaBean( "" + mapaControleContaRelatorioHelper.getIdEmpresa(), mapaControleContaRelatorioHelper.getNomeEmpresa(), "" + Util.adicionarZerosEsquedaNumero(3,idLocalidadeAtual.toString()), "" + mapaControleContaRelatorioHelper.getSequencialInicial(), "" + mapaControleContaRelatorioHelper.getSequencialFinal(), "" + mapaControleContaRelatorioHelper.getIdEsferaPoder(), "" + qtdTotalFirma, "" + qtdTotalCorreios, "" + qtdTotalPublico, "" + qtdTotalMacro, "" + qtdTotalContas, "" + qtdTotalGeralFirma, "" + qtdTotalGeralCorreio, "" + qtdTotalGeralPublico, "" + qtdTotalGeral); retorno.add(relatorioResumoContaLocalidadeBean); primeirVez = true; } } } return retorno; } /** * M�todo que executa a tarefa * * @return Object * */ public Object executar() throws TarefaException { // ------------------------------------ Integer idFuncionalidadeIniciada = this.getIdFuncionalidadeIniciada(); // ------------------------------------ Fachada fachada = Fachada.getInstancia(); String mesAno = (String) getParametro("mesAno"); String idGrupoFaturamento = (String) getParametro("idGrupoFaturamento"); Empresa firma = (Empresa) getParametro("firma"); String vencimento = (String) getParametro("vencimento"); Collection colecaoResumoContaLocalidadeConta = (Collection) getParametro("colecaoResumoContaLocalidadeConta"); int tipoFormatoRelatorio = (Integer) getParametro("tipoFormatoRelatorio"); // valor de retorno byte[] retorno = null; // Par�metros do relat�rio Map<String, String> parametros = new HashMap(); SistemaParametro sistemaParametro = fachada.pesquisarParametrosDoSistema(); parametros.put("imagem", sistemaParametro.getImagemRelatorio()); parametros.put("imagemConta", sistemaParametro.getImagemConta()); parametros.put("mesAno",mesAno); parametros.put("vencimento", vencimento); parametros.put("idGrupoFaturamento",idGrupoFaturamento); if (firma != null) { parametros.put("firma", firma.getDescricao()); } else { parametros.put("firma", null); } Collection dadosRelatorio = colecaoResumoContaLocalidadeConta; Collection<RelatorioMapaControleContaBean> colecaoBean = this .inicializarBeanRelatorio(dadosRelatorio); if (colecaoBean == null || colecaoBean.isEmpty()) { // N�o existem dados para a exibi��o do relat�rio. throw new ActionServletException("atencao.pesquisa.nenhumresultado"); } RelatorioDataSource ds = new RelatorioDataSource((java.util.List) colecaoBean); retorno = this.gerarRelatorio(ConstantesRelatorios.RELATORIO_RESUMO_CONTA_LOCALIDADE, parametros, ds, tipoFormatoRelatorio); // ------------------------------------ // Grava o relat�rio no sistema try { persistirRelatorioConcluido(retorno, Relatorio.RESUMO_CONTA_LOCALIDADE, idFuncionalidadeIniciada); } catch (ControladorException e) { e.printStackTrace(); throw new TarefaException("Erro ao gravar relat�rio no sistema", e); } // ------------------------------------ // retorna o relat�rio gerado return retorno; } @Override public int calcularTotalRegistrosRelatorio() { // Integer mesAnoInteger = (Integer) getParametro("mesAnoInteger"); // Integer idGrupoFaturamento = (Integer) getParametro("idGrupoFaturamento"); // Collection idEsferaPoder = (Collection) getParametro("colecaoIdEsferaPoder"); return 0; } public void agendarTarefaBatch() { AgendadorTarefas.agendarTarefa("RelatorioMapaControleConta", this); } }