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;
/**
* classe respons�vel por criar o relat�rio de imoveis com faturas em atraso
*
* @author Bruno Barros
* @created 10/12/2007
*/
public class RelatorioImoveisFaturasAtrasoDescritasLocalizacao extends TarefaRelatorio {
public RelatorioImoveisFaturasAtrasoDescritasLocalizacao(Usuario usuario, String nomeRelatorio) {
super(usuario, nomeRelatorio);
}
private static final long serialVersionUID = 1L;
public RelatorioImoveisFaturasAtrasoDescritasLocalizacao(Usuario usuario) {
super(usuario, ConstantesRelatorios.RELATORIO_IMOVEIS_FATURAS_ATRASO_DESCRITAS_LOCALIZACAO);
}
@Deprecated
public RelatorioImoveisFaturasAtrasoDescritasLocalizacao() {
super(null, "");
}
public Object executar() throws TarefaException {
int tipoFormatoRelatorio = (Integer) getParametro("tipoFormatoRelatorio");
FiltrarRelatorioImoveisFaturasAtrasoHelper filtro =
(FiltrarRelatorioImoveisFaturasAtrasoHelper) getParametro("filtrarRelatorioImoveisFaturasAtrasoHelper");
RelatorioDataSource ds = new RelatorioDataSource( executarConsultaECriarBeans(filtro) );
byte[] retorno = gerarRelatorio(ConstantesRelatorios.RELATORIO_IMOVEIS_FATURAS_ATRASO_DESCRITAS_LOCALIZACAO,
criarParametros(), ds, tipoFormatoRelatorio);
try {
persistirRelatorioConcluido(retorno, Relatorio.IMOVEIS_FATURAS_ATRASO_DESCRITAS_LOCALIZACAO,
this.getIdFuncionalidadeIniciada());
} catch (ControladorException e) {
e.printStackTrace();
throw new TarefaException("Erro ao gravar relat�rio no sistema", e);
}
return retorno;
}
/**
*[UC ] -
*[SB ] -
*[FS ] -
*
* comment
*
*@since 15/09/2009
*@author Marlon Patrick
*/
private Map<String, Object> criarParametros() {
Map<String,Object> parametros = new HashMap<String,Object>();
SistemaParametro sistemaParametro = Fachada.getInstancia().pesquisarParametrosDoSistema();
parametros.put("imagem", sistemaParametro.getImagemRelatorio());
parametros.put("gerRegionalFiltro", getParametro("gerRegionalFiltro"));
parametros.put("uniNegocioFiltro",getParametro("uniNegocioFiltro"));
parametros.put("qtdFaturasFiltro", getParametro("qtdFaturasFiltro"));
parametros.put("localidadeFiltro", getParametro("localidadeFiltro"));
parametros.put("setorFiltro", getParametro("setorFiltro"));
parametros.put("rotaFiltro", getParametro("rotaFiltro"));
parametros.put("refFaturasFiltro", getParametro("refFaturasFiltro"));
parametros.put("seqRotaFiltro", getParametro("seqRotaFiltro"));
parametros.put("valorFaturasFiltro",getParametro("valorFaturasFiltro"));
parametros.put("esfPoderFiltro", getParametro("esfPoderFiltro"));
parametros.put("LigAguaFiltro", getParametro("LigAguaFiltro"));
parametros.put("categoriaFiltro", getParametro("categoriaFiltro"));
parametros.put("hidrometro", getParametro("hidrometro"));
return parametros;
}
/**
*[UC ] -
*[SB ] -
*[FS ] -
*
* comment
*
*@since 15/09/2009
*@author Marlon Patrick
*/
private List<RelatorioImoveisFaturasAtrasoBean> executarConsultaECriarBeans(FiltrarRelatorioImoveisFaturasAtrasoHelper filtro) {
List<RelatorioImoveisFaturasAtrasoBean> relatorioBeans = new ArrayList<RelatorioImoveisFaturasAtrasoBean>();
RelatorioImoveisFaturasAtrasoBean relatorioImoveisFaturasAtrasoBean = null;
Collection<RelatorioImoveisFaturasAtrasoHelper> colecao =
Fachada.getInstancia().pesquisarRelatorioImoveisFaturasAtrasoDescritasLocalizacao(filtro);
if ( !Util.isVazioOrNulo(colecao)) {
Iterator<RelatorioImoveisFaturasAtrasoHelper> colecaoIterator = colecao.iterator();
RelatorioImoveisFaturasAtrasoHelper helperAnterior = null;
List<RelatorioImoveisFaturasAtrasoContasBean> colecaoDadosSubrelatorio = new ArrayList<RelatorioImoveisFaturasAtrasoContasBean>();
BigDecimal totalImovel = BigDecimal.ZERO;
int qtdFaturasAtraso = 0;
while (colecaoIterator.hasNext()) {
RelatorioImoveisFaturasAtrasoHelper helper = colecaoIterator.next();
if (helperAnterior == null) {
helperAnterior = helper;
}
if (helperAnterior.getMatriculaImovel().equals(helper.getMatriculaImovel())) {
RelatorioImoveisFaturasAtrasoContasBean relatorioImoveisFaturasAtrasoContasBean = new RelatorioImoveisFaturasAtrasoContasBean(Util.formatarAnoMesParaMesAno(helper.getReferenciaFaturasAtrasoInicial()), helper.getValorFaturasAtrasoSemEncargos(), helper.getVencimento());
colecaoDadosSubrelatorio.add(relatorioImoveisFaturasAtrasoContasBean);
qtdFaturasAtraso++;
totalImovel = totalImovel.add(helper.getValorFaturasAtrasoSemEncargos());
} else {
helperAnterior.setQuantidadeFaturasAtraso(qtdFaturasAtraso);
relatorioImoveisFaturasAtrasoBean =
new RelatorioImoveisFaturasAtrasoBean(helperAnterior, colecaoDadosSubrelatorio);
relatorioImoveisFaturasAtrasoBean.setValorTotalFaturaAtrasoSemEncargo(totalImovel);
if(isQtdContasDentroIntervaloInformado(filtro, relatorioImoveisFaturasAtrasoBean)
&& isValorFaturasDentroIntervaloInformado(filtro, relatorioImoveisFaturasAtrasoBean)){
relatorioBeans.add(relatorioImoveisFaturasAtrasoBean);
}
colecaoDadosSubrelatorio.clear();
RelatorioImoveisFaturasAtrasoContasBean relatorioImoveisFaturasAtrasoContasBean = new RelatorioImoveisFaturasAtrasoContasBean(Util.formatarAnoMesParaMesAno(helper.getReferenciaFaturasAtrasoInicial()), helper.getValorFaturasAtrasoSemEncargos(), helper.getVencimento());
colecaoDadosSubrelatorio.add(relatorioImoveisFaturasAtrasoContasBean);
totalImovel = BigDecimal.ZERO;
totalImovel = totalImovel.add(helper.getValorFaturasAtrasoSemEncargos());
qtdFaturasAtraso = 1;
}
if(!colecaoIterator.hasNext()){
relatorioImoveisFaturasAtrasoBean =
new RelatorioImoveisFaturasAtrasoBean(helperAnterior, colecaoDadosSubrelatorio);
relatorioImoveisFaturasAtrasoBean.setValorTotalFaturaAtrasoSemEncargo(totalImovel);
if(isQtdContasDentroIntervaloInformado(filtro, relatorioImoveisFaturasAtrasoBean)
&& isValorFaturasDentroIntervaloInformado(filtro, relatorioImoveisFaturasAtrasoBean)){
relatorioBeans.add(relatorioImoveisFaturasAtrasoBean);
}
colecaoDadosSubrelatorio.clear();
RelatorioImoveisFaturasAtrasoContasBean relatorioImoveisFaturasAtrasoContasBean = new RelatorioImoveisFaturasAtrasoContasBean(Util.formatarAnoMesParaMesAno(helper.getReferenciaFaturasAtrasoInicial()), helper.getValorFaturasAtrasoSemEncargos(), helper.getVencimento());
colecaoDadosSubrelatorio.add(relatorioImoveisFaturasAtrasoContasBean);
totalImovel = BigDecimal.ZERO;
totalImovel = totalImovel.add(helper.getValorFaturasAtrasoSemEncargos());
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());
}
@Override
public int calcularTotalRegistrosRelatorio() {
int retorno = 0;
retorno =
Fachada.getInstancia().pesquisarTotalRegistroRelatorioImoveisFaturasAtrasoLocalizacao(
(FiltrarRelatorioImoveisFaturasAtrasoHelper)
getParametro("filtrarRelatorioImoveisFaturasAtrasoHelper"));
if(retorno == 0){
throw new ActionServletException("atencao.pesquisa.nenhumresultado", null, "Relat�rio");
}
return retorno;
}
public void agendarTarefaBatch() {
AgendadorTarefas.agendarTarefa("RelatorioImoveisFaturasAtraso", this);
}
}