package gcom.relatorio.cadastro.localidade; import gcom.batch.Relatorio; import gcom.cadastro.localidade.FiltroSetorComercial; import gcom.cadastro.localidade.SetorComercial; import gcom.cadastro.sistemaparametro.SistemaParametro; import gcom.fachada.Fachada; 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 not attributable * @version 1.0 */ public class RelatorioManterSetorComercial extends TarefaRelatorio { private static final long serialVersionUID = 1L; public RelatorioManterSetorComercial(Usuario usuario) { super(usuario, ConstantesRelatorios.RELATORIO_SETOR_COMERCIAL_MANTER); } @Deprecated public RelatorioManterSetorComercial() { super(null, ""); } /** * < <Descri��o do m�todo>> * * @param setoresComerciais * Description of the Parameter * @param setorComercialParametros * 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(); // ------------------------------------ FiltroSetorComercial filtroSetorComercial = (FiltroSetorComercial) getParametro("filtroSetorComercial"); SetorComercial setorComercialParametros = (SetorComercial) getParametro("setorComercialParametros"); int tipoFormatoRelatorio = (Integer) getParametro("tipoFormatoRelatorio"); // valor de retorno byte[] retorno = null; Fachada fachada = Fachada.getInstancia(); // cole��o de beans do relat�rio List relatorioBeans = new ArrayList(); RelatorioManterSetorComercialBean relatorioBean = null; filtroSetorComercial .adicionarCaminhoParaCarregamentoEntidade("localidade"); filtroSetorComercial .adicionarCaminhoParaCarregamentoEntidade("municipio"); filtroSetorComercial.setConsultaSemLimites(true); Collection setoresComerciais = fachada.pesquisar(filtroSetorComercial, SetorComercial.class.getName()); // se a cole��o de par�metros da analise n�o for vazia if (setoresComerciais != null && !setoresComerciais.isEmpty()) { // Organizar a cole��o Collections.sort((List) setoresComerciais, new Comparator() { public int compare(Object a, Object b) { String localidade1 = ((SetorComercial) a).getLocalidade() .getDescricao(); String localidade2 = ((SetorComercial) b).getLocalidade() .getDescricao(); return localidade1.compareTo(localidade2); } }); // coloca a cole��o de par�metros da analise no iterator Iterator setorComercialIterator = setoresComerciais.iterator(); // la�o para criar a cole��o de par�metros da analise while (setorComercialIterator.hasNext()) { SetorComercial setorComercial = (SetorComercial) setorComercialIterator .next(); relatorioBean = new RelatorioManterSetorComercialBean( // Localidade setorComercial.getLocalidade().getDescricao(), // C�digo "" + setorComercial.getCodigo(), // Descri��o setorComercial.getDescricao(), // Munic�pio setorComercial.getMunicipio() .getNome(), // Indicador Uso setorComercial.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()); parametros.put("codigo", setorComercialParametros.getCodigo() == 0 ? "" : "" + setorComercialParametros.getCodigo()); parametros.put("nome", setorComercialParametros.getDescricao()); parametros.put("idLocalidade", setorComercialParametros.getLocalidade() .getId() == null ? "" : "" + setorComercialParametros.getLocalidade().getId()); parametros.put("nomeLocalidade", setorComercialParametros .getLocalidade().getDescricao()); parametros.put("idMunicipio", setorComercialParametros.getMunicipio() .getId() == null ? "" : "" + setorComercialParametros.getMunicipio().getId()); parametros.put("nomeMunicipio", setorComercialParametros.getMunicipio() .getNome()); String indicadorUso = ""; if (setorComercialParametros.getIndicadorUso() != null && !setorComercialParametros.getIndicadorUso().equals("")) { if (setorComercialParametros.getIndicadorUso().equals( new Short("1"))) { indicadorUso = "Ativo"; } else if (setorComercialParametros.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_SETOR_COMERCIAL_MANTER, parametros, ds, tipoFormatoRelatorio); // ------------------------------------ // Grava o relat�rio no sistema try { persistirRelatorioConcluido(retorno, Relatorio.MANTER_SETOR_COMERCIAL, 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( (FiltroSetorComercial) getParametro("filtroSetorComercial"), SetorComercial.class.getName()); return retorno; } public void agendarTarefaBatch() { AgendadorTarefas.agendarTarefa("RelatorioManterSetorComercial", this); } }