package gcom.relatorio.micromedicao.rota; import gcom.batch.Relatorio; import gcom.cadastro.sistemaparametro.SistemaParametro; import gcom.fachada.Fachada; import gcom.micromedicao.FiltroRota; import gcom.micromedicao.Rota; 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.agendadortarefas.AgendadorTarefas; import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import java.util.Comparator; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; /** * <p> * Title: GCOM * </p> * <p> * Description: Sistema de Gest�o Comercial * </p> * <p> * Copyright: Copyright (c) 2004 * </p> * <p> * Company: COMPESA - Companhia Pernambucana de Saneamento * </p> * * @author Rafael Corr�a * @version 1.0 */ public class RelatorioManterRota extends TarefaRelatorio { private static final long serialVersionUID = 1L; public RelatorioManterRota(Usuario usuario) { super(usuario, ConstantesRelatorios.RELATORIO_ROTA_MANTER); } @Deprecated public RelatorioManterRota() { super(null, ""); } /** * < <Descri��o do m�todo>> * * @param localidades * Description of the Parameter * @param localidadeParametros * Description of the Parameter * @return Descri��o do retorno * @exception RelatorioVazioException * Descri��o da exce��o */ public Object executar() throws TarefaException { // ------------------------------------ Integer idFuncionalidadeIniciada = this.getIdFuncionalidadeIniciada(); // ------------------------------------ FiltroRota filtroRota = (FiltroRota) getParametro("filtroRota"); Rota rotaParametros = (Rota) getParametro("rotaParametros"); int tipoFormatoRelatorio = (Integer) getParametro("tipoFormatoRelatorio"); // valor de retorno byte[] retorno = null; // cole��o de beans do relat�rio List relatorioBeans = new ArrayList(); RelatorioManterRotaBean relatorioBean = null; Fachada fachada = Fachada.getInstancia(); rotaParametros.getFaturamentoGrupo(); filtroRota.adicionarCaminhoParaCarregamentoEntidade("empresa"); filtroRota.adicionarCaminhoParaCarregamentoEntidade("leituraTipo"); filtroRota.adicionarCaminhoParaCarregamentoEntidade("cobrancaGrupo"); filtroRota.adicionarCaminhoParaCarregamentoEntidade("faturamentoGrupo"); filtroRota .adicionarCaminhoParaCarregamentoEntidade("setorComercial.localidade"); filtroRota.adicionarCaminhoParaCarregamentoEntidade("empresaEntregaContas"); filtroRota.adicionarCaminhoParaCarregamentoEntidade("empresaCobranca"); filtroRota.setConsultaSemLimites(true); Collection colecaoRotas = fachada.pesquisar(filtroRota, Rota.class .getName()); // se a cole��o de par�metros da analise n�o for vazia if (colecaoRotas != null && !colecaoRotas.isEmpty()) { // Organizar a cole��o Collections.sort((List) colecaoRotas, new Comparator() { public int compare(Object a, Object b) { String setor1 = "" + ((Rota) a).getSetorComercial().getLocalidade() .getId() + ((Rota) a).getSetorComercial().getCodigo(); String setor2 = "" + ((Rota) b).getSetorComercial().getLocalidade() .getId() + ((Rota) b).getSetorComercial().getCodigo(); return setor1.compareTo(setor2); } }); // coloca a cole��o de par�metros da analise no iterator Iterator colecaoRotasIterator = colecaoRotas.iterator(); // la�o para criar a cole��o de par�metros da analise while (colecaoRotasIterator.hasNext()) { Rota rota = (Rota) colecaoRotasIterator.next(); // Faz as valida��es dos campos necess�riose e formata a String // para a forma como ir� aparecer no relat�rio String setorComercial = ""; String localidade = ""; if (rota.getSetorComercial() != null) { setorComercial = rota.getSetorComercial().getCodigo() + " - " + rota.getSetorComercial().getDescricao(); if (rota.getSetorComercial().getLocalidade() != null) { localidade = rota.getSetorComercial().getLocalidade() .getId().toString() + " - " + rota.getSetorComercial().getLocalidade() .getDescricao(); } } String tipoLeitura = ""; if (rota.getLeituraTipo() != null) { tipoLeitura = rota.getLeituraTipo().getDescricao(); } String empresa = ""; if (rota.getEmpresa() != null) { empresa = rota.getEmpresa().getDescricao(); } String empresaCobranca = ""; if (rota.getEmpresaCobranca() != null) { empresaCobranca = rota.getEmpresaCobranca().getDescricao(); } String empresaEntregaContas = ""; if (rota.getEmpresaEntregaContas() != null) { empresaEntregaContas = rota.getEmpresaEntregaContas().getDescricao(); } relatorioBean = new RelatorioManterRotaBean( // C�digo "" + rota.getCodigo(), // Localidade localidade, // Setor Comercial setorComercial, // Grupo de Faturamento rota.getFaturamentoGrupo().getDescricao(), // Grupo de Cobran�a rota.getCobrancaGrupo().getDescricao(), // Tipo de Leitura tipoLeitura, // Empresa empresa, //Empresa Cobranca empresaCobranca, //Empresa Entrega Contas empresaEntregaContas, // Indicador Uso rota.getIndicadorUso().toString()); // adiciona o bean a cole��o relatorioBeans.add(relatorioBean); } } // Par�metros do relat�rio Map parametros = new HashMap(); // adiciona os par�metros do relat�rio // adiciona o laudo da an�lise SistemaParametro sistemaParametro = fachada .pesquisarParametrosDoSistema(); parametros.put("imagem", sistemaParametro.getImagemRelatorio()); if (rotaParametros.getCodigo() != null) { parametros.put("codigo", rotaParametros.getCodigo().toString()); } else { parametros.put("codigo", ""); } if (rotaParametros.getSetorComercial().getLocalidade().getId() != null) { parametros.put("idLocalidade", rotaParametros.getSetorComercial() .getLocalidade().getId().toString()); } else { parametros.put("idLocalidade", ""); } parametros.put("nomeLocalidade", rotaParametros.getSetorComercial() .getLocalidade().getDescricao()); if (rotaParametros.getSetorComercial().getId() != null) { parametros.put("idSetorComercial", "" + rotaParametros.getSetorComercial().getCodigo()); } else { parametros.put("idSetorComercial", ""); } parametros.put("nomeSetorComercial", rotaParametros.getSetorComercial() .getDescricao()); parametros.put("grupoFaturamento", rotaParametros.getFaturamentoGrupo() .getDescricao()); String indicadorUso = ""; if (rotaParametros.getIndicadorUso() != null && !rotaParametros.getIndicadorUso().equals("")) { if (rotaParametros.getIndicadorUso().equals(new Short("1"))) { indicadorUso = "Ativo"; } else if (rotaParametros.getIndicadorUso().equals(new Short("2"))) { indicadorUso = "Inativo"; } } parametros.put("indicadorUso", indicadorUso); // cria uma inst�ncia do dataSource do relat�rio RelatorioDataSource ds = new RelatorioDataSource(relatorioBeans); retorno = this.gerarRelatorio( ConstantesRelatorios.RELATORIO_ROTA_MANTER, parametros, ds, tipoFormatoRelatorio); // ------------------------------------ // Grava o relat�rio no sistema try { persistirRelatorioConcluido(retorno, Relatorio.MANTER_ROTA, 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() { int retorno = 0; retorno = Fachada.getInstancia().totalRegistrosPesquisa( (FiltroRota) getParametro("filtroRota"), Rota.class.getName()); return retorno; } public void agendarTarefaBatch() { AgendadorTarefas.agendarTarefa("RelatorioManterRota", this); } }