package gcom.relatorio.cadastro.imovel; import gcom.batch.Relatorio; import gcom.cadastro.sistemaparametro.SistemaParametro; import gcom.fachada.Fachada; import gcom.gui.ActionServletException; import gcom.relatorio.ConstantesRelatorios; import gcom.relatorio.RelatorioDataSource; 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.math.BigDecimal; import java.util.ArrayList; import java.util.Collection; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; /** * Respons�vel pela l�gica de Relat�rio de Im�veis com Fatura em Atraso * Descritas, com crit�tio de filtro por Cliente. * * @author Marlon Patrick * @since 02/09/2009 */ public class RelatorioImoveisFaturasAtrasoDescritasCliente extends TarefaRelatorio { private static final long serialVersionUID = 1L; public RelatorioImoveisFaturasAtrasoDescritasCliente(Usuario usuario) { super(usuario, ConstantesRelatorios.RELATORIO_IMOVEIS_FATURAS_ATRASO_DESCRITAS_CLIENTE); } @Deprecated public RelatorioImoveisFaturasAtrasoDescritasCliente() { super(null, ""); } public Object executar() throws TarefaException { FiltrarRelatorioImoveisFaturasAtrasoHelper filtro = (FiltrarRelatorioImoveisFaturasAtrasoHelper) getParametro("filtrarRelatorioImoveisFaturasAtrasoHelper"); RelatorioDataSource ds = new RelatorioDataSource( executarConsultaECriarColecaoRelatorioBeans(filtro) ); int tipoFormatoRelatorio = (Integer) getParametro("tipoFormatoRelatorio"); byte[] retorno = gerarRelatorio(ConstantesRelatorios.RELATORIO_IMOVEIS_FATURAS_ATRASO_DESCRITAS_CLIENTE, criarParametrosRelatorio(), ds, tipoFormatoRelatorio); try { persistirRelatorioConcluido(retorno, Relatorio.IMOVEIS_FATURAS_ATRASO_DESCRITAS_CLIENTE, this.getIdFuncionalidadeIniciada()); } catch (ControladorException e) { e.printStackTrace(); throw new TarefaException("Erro ao gravar relat�rio no sistema", e); } return retorno; } /** * Executa a consulta no banco e com o resultado * cria os objetos RelatorioBeans. * *@since 02/09/2009 *@author Marlon Patrick */ private List<RelatorioImoveisFaturasAtrasoBean> executarConsultaECriarColecaoRelatorioBeans( FiltrarRelatorioImoveisFaturasAtrasoHelper filtro) { List<RelatorioImoveisFaturasAtrasoBean> relatorioBeans = new ArrayList<RelatorioImoveisFaturasAtrasoBean>(); Collection<RelatorioImoveisFaturasAtrasoHelper> colecao = Fachada.getInstancia().pesquisarRelatorioImoveisFaturasAtrasoDescritasCliente(filtro); if ( !Util.isVazioOrNulo(colecao)) { Iterator<RelatorioImoveisFaturasAtrasoHelper> colecaoIterator = colecao.iterator(); RelatorioImoveisFaturasAtrasoHelper helperAnterior = null; Collection<RelatorioImoveisFaturasAtrasoContasBean> colecaoDadosSubrelatorio = new ArrayList<RelatorioImoveisFaturasAtrasoContasBean>(); BigDecimal totalFaturasSemEncargos = BigDecimal.ZERO; BigDecimal totalFaturasComEncargos = BigDecimal.ZERO; int qtdFaturasAtraso = 0; while (colecaoIterator.hasNext()) { RelatorioImoveisFaturasAtrasoHelper helper = colecaoIterator.next(); if (helperAnterior == null) { helperAnterior = helper; } if (helperAnterior.getIdImovel().equals(helper.getIdImovel()) && helperAnterior.getIdCliente().equals(helper.getIdCliente())) { colecaoDadosSubrelatorio.add(new RelatorioImoveisFaturasAtrasoContasBean(helper)); qtdFaturasAtraso++; totalFaturasSemEncargos = totalFaturasSemEncargos.add(helper.getValorFaturasAtrasoSemEncargos()); totalFaturasComEncargos = totalFaturasComEncargos.add(helper.getValorFaturasAtrasoComEncargos()); } else { helperAnterior.setQuantidadeFaturasAtraso(qtdFaturasAtraso); RelatorioImoveisFaturasAtrasoBean relatorioAux = new RelatorioImoveisFaturasAtrasoBean(helperAnterior, colecaoDadosSubrelatorio); relatorioAux.setValorTotalFaturaAtrasoSemEncargo(totalFaturasSemEncargos); relatorioAux.setValorTotalFaturaAtrasoComEncargo(totalFaturasComEncargos); if(isQtdContasDentroIntervaloInformado(filtro, relatorioAux) && isValorFaturasDentroIntervaloInformado(filtro, relatorioAux)){ relatorioBeans.add(relatorioAux); } colecaoDadosSubrelatorio.clear(); colecaoDadosSubrelatorio.add(new RelatorioImoveisFaturasAtrasoContasBean(helper)); totalFaturasSemEncargos = BigDecimal.ZERO; totalFaturasComEncargos = BigDecimal.ZERO; totalFaturasSemEncargos = totalFaturasSemEncargos.add(helper.getValorFaturasAtrasoSemEncargos()); totalFaturasComEncargos = totalFaturasComEncargos.add(helper.getValorFaturasAtrasoComEncargos()); qtdFaturasAtraso = 1; } if(!colecaoIterator.hasNext()){ helperAnterior.setQuantidadeFaturasAtraso(qtdFaturasAtraso); RelatorioImoveisFaturasAtrasoBean relatorioAux = new RelatorioImoveisFaturasAtrasoBean(helperAnterior, colecaoDadosSubrelatorio); relatorioAux.setValorTotalFaturaAtrasoSemEncargo(totalFaturasSemEncargos); relatorioAux.setValorTotalFaturaAtrasoComEncargo(totalFaturasComEncargos); if(isQtdContasDentroIntervaloInformado(filtro, relatorioAux) && isValorFaturasDentroIntervaloInformado(filtro, relatorioAux)){ relatorioBeans.add(relatorioAux); } colecaoDadosSubrelatorio.clear(); colecaoDadosSubrelatorio.add(new RelatorioImoveisFaturasAtrasoContasBean(helper)); totalFaturasSemEncargos = totalFaturasSemEncargos.add(helper.getValorFaturasAtrasoSemEncargos()); totalFaturasComEncargos = totalFaturasComEncargos.add(helper.getValorFaturasAtrasoComEncargos()); totalFaturasSemEncargos = BigDecimal.ZERO; totalFaturasComEncargos = BigDecimal.ZERO; qtdFaturasAtraso = 0; } helperAnterior = helper; } } return relatorioBeans; } /** *[CRC] - 1672 - Melhorar performance dos relat�rios de Im�veis com Fatura em Atraso.<br/> * *Esse m�todo verifica se um RelatorioBean possui um numero de contas *dentro do intervalo informado pelo usu�rio. Essa verifica��o tornou-se necess�ria *neste momento da gera��o do relat�rio pois aqui sabemos exatamente quantas contas *em atraso o im�vel tem. Foi preferido fazer isso via c�digo Java ao inv�s de sql/hql *pois no caso desse relatorio a query n�o agrupa nenhum valor de conta, *assim ao colocarmos isso num having count o mesmo n�o traria o resultado correto. * *@since 10/09/2009 *@author Marlon Patrick */ private boolean isQtdContasDentroIntervaloInformado(FiltrarRelatorioImoveisFaturasAtrasoHelper filtro, RelatorioImoveisFaturasAtrasoBean relatorioAux){ if(filtro.getQuantidadeFaturasAtrasoInicial() == null || filtro.getQuantidadeFaturasAtrasoFinal() == null){ return true; } return (relatorioAux.getArrayRelatorioImoveisFaturasAtrasoContasBean().size() >= filtro.getQuantidadeFaturasAtrasoInicial() && relatorioAux.getArrayRelatorioImoveisFaturasAtrasoContasBean().size() <= filtro.getQuantidadeFaturasAtrasoFinal()); } /** * Idem isQtdContasDentroIntervaloInformado(filtro,relatorioAux) * *@since 10/09/2009 *@author Marlon Patrick */ private boolean isValorFaturasDentroIntervaloInformado(FiltrarRelatorioImoveisFaturasAtrasoHelper filtro, RelatorioImoveisFaturasAtrasoBean relatorioAux){ if(filtro.getValorFaturasAtrasoInicial() == null || filtro.getValorFaturasAtrasoFinal() == null){ return true; } return (relatorioAux.getValorTotalFaturaAtrasoSemEncargo().doubleValue() >= filtro.getValorFaturasAtrasoInicial() && relatorioAux.getValorTotalFaturaAtrasoSemEncargo().doubleValue() <= filtro.getValorFaturasAtrasoFinal()); } /** * M�todo configura os parametros que ser�o exibidos no relat�rio * como sendo os filtros utilizados pelo usuario para ger�-lo. * *@since 02/09/2009 *@author Marlon Patrick */ private Map<String, Object> criarParametrosRelatorio() { Map<String,Object> parametros = new HashMap<String,Object>(); SistemaParametro sistemaParametro = Fachada.getInstancia().pesquisarParametrosDoSistema(); parametros.put("imagem", sistemaParametro.getImagemRelatorio()); parametros.put("clienteSuperiorFiltro", getParametro("clienteSuperiorFiltro")); parametros.put("clienteFiltro", getParametro("clienteFiltro")); parametros.put("tipoRelacaoFiltro", getParametro("tipoRelacaoFiltro")); parametros.put("responsavelFiltro", getParametro("responsavelFiltro")); parametros.put("hidrometro", getParametro("hidrometro")); parametros.put("esfPoderFiltro", getParametro("esfPoderFiltro")); parametros.put("LigAguaFiltro", getParametro("LigAguaFiltro")); parametros.put("categoriaFiltro", getParametro("categoriaFiltro")); parametros.put("situacaoCobrancaFiltro", getParametro("situacaoCobrancaFiltro")); parametros.put("qtdFaturasFiltro", getParametro("qtdFaturasFiltro")); parametros.put("refFaturasFiltro", getParametro("refFaturasFiltro")); parametros.put("valorFaturasFiltro",getParametro("valorFaturasFiltro")); return parametros; } @Override public int calcularTotalRegistrosRelatorio() { int retorno = 0; retorno = Fachada.getInstancia().pesquisarTotalRegistroRelatorioImoveisFaturasAtrasoCliente( (FiltrarRelatorioImoveisFaturasAtrasoHelper) getParametro("filtrarRelatorioImoveisFaturasAtrasoHelper")); if(retorno == 0){ throw new ActionServletException("atencao.pesquisa.nenhumresultado", null, "Relat�rio"); } return retorno; } public void agendarTarefaBatch() { AgendadorTarefas.agendarTarefa("RelatorioImoveisFaturasAtraso", this); } }