package gcom.relatorio.arrecadacao;
import gcom.batch.Relatorio;
import gcom.cadastro.localidade.FiltroGerenciaRegional;
import gcom.cadastro.localidade.FiltroUnidadeNegocio;
import gcom.cadastro.localidade.GerenciaRegional;
import gcom.cadastro.localidade.UnidadeNegocio;
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.Util;
import gcom.util.agendadortarefas.AgendadorTarefas;
import gcom.util.filtro.ParametroSimples;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* [UC00744] Gerar Comparativo do Faturamento, Arrecada��o e Expurgo
*
* @author S�vio Luiz
*
* @date 09/12/2008
*/
public class RelatorioComparativoFatArrecExpurgado extends TarefaRelatorio {
private static final long serialVersionUID = 1L;
public RelatorioComparativoFatArrecExpurgado(Usuario usuario) {
super(usuario,
ConstantesRelatorios.RELATORIO_COMPARATIVO_FATURAMENTO_ARRECADACAO_EXPURGO);
}
int quantidadeRegistros;
@Deprecated
public RelatorioComparativoFatArrecExpurgado() {
super(null, "");
}
/**
* < <Descri��o do m�todo>>
*
* @param bairros
* Description of the Parameter
* @param bairroParametros
* Description of the Parameter
* @return Descri��o do retorno
* @exception RelatorioVazioException
* Descri��o da exce��o
*/
public Object executar() throws TarefaException {
// valor de retorno
byte[] retorno = null;
// ------------------------------------
Integer idFuncionalidadeIniciada = this.getIdFuncionalidadeIniciada();
// ------------------------------------
int tipoFormatoRelatorio = (Integer) getParametro("tipoFormatoRelatorio");
String gerenciaRegional = (String) getParametro("gerenciaRegional");
String unidadeNegocio = (String) getParametro("unidadeNegocio");
String mesAnoReferencia = (String) getParametro("mesAnoreferencia");
Integer anoMesreferencia = Util
.formatarMesAnoComBarraParaAnoMes(mesAnoReferencia);
// cole��o de beans do relat�rio
List relatorioBeans = new ArrayList();
Fachada fachada = Fachada.getInstancia();
Collection<RelatorioComparativoFatArrecExpurgoBean> colecaoComparativoExpurgoBean = fachada
.pesquisarDadosComparativosFaturamentoArrecadacaoExpurgo(
anoMesreferencia, gerenciaRegional, unidadeNegocio);
// adiciona o bean a cole��o
relatorioBeans.addAll(colecaoComparativoExpurgoBean);
// __________________________________________________________________
// 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("mesAnoReferencia", mesAnoReferencia);
if ((gerenciaRegional == null || gerenciaRegional.equals(""))
&& (unidadeNegocio == null || unidadeNegocio.equals(""))) {
parametros.put("opcaoTotalizacao", "ESTADO");
}else{
if(gerenciaRegional != null && !gerenciaRegional.equals("")){
FiltroGerenciaRegional filtroGerenciaRegional = new FiltroGerenciaRegional();
filtroGerenciaRegional.adicionarParametro(new ParametroSimples(FiltroGerenciaRegional.ID,gerenciaRegional));
Collection colecaoGR = fachada.pesquisar(filtroGerenciaRegional,GerenciaRegional.class.getName());
GerenciaRegional grBase = (GerenciaRegional)Util.retonarObjetoDeColecao(colecaoGR);
parametros.put("opcaoTotalizacao", "GER�NCIA REGIONAL - "+grBase.getNome().toUpperCase());
}
if(unidadeNegocio != null && !unidadeNegocio.equals("")){
FiltroUnidadeNegocio filtroUnidadeNegocio = new FiltroUnidadeNegocio();
filtroUnidadeNegocio.adicionarParametro(new ParametroSimples(FiltroUnidadeNegocio.ID,unidadeNegocio));
Collection colecaoUN = fachada.pesquisar(filtroUnidadeNegocio,UnidadeNegocio.class.getName());
UnidadeNegocio unBase = (UnidadeNegocio)Util.retonarObjetoDeColecao(colecaoUN);
parametros.put("opcaoTotalizacao", "UNIDADE NEG�CIO - "+unBase.getNome().toUpperCase());
}
}
parametros.put("imagem", sistemaParametro.getImagemRelatorio());
parametros.put("tipoRelatorio", "R0744");
// cria uma inst�ncia do dataSource do relat�rio
RelatorioDataSource ds = new RelatorioDataSource(relatorioBeans);
retorno = gerarRelatorio(
ConstantesRelatorios.RELATORIO_COMPARATIVO_FATURAMENTO_ARRECADACAO_EXPURGO,
parametros, ds, tipoFormatoRelatorio);
// ------------------------------------
// Grava o relat�rio no sistema
try {
persistirRelatorioConcluido(retorno,
Relatorio.COMPARATIVO_FATURAMENTO_ARRECADACAO_EXPURGO, 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 anoMesreferencia = Util
.formatarMesAnoComBarraParaAnoMes((String)getParametro("mesAnoreferencia"));
int retorno = Fachada
.getInstancia()
.pesquisarQuantidadeDadosComparativosFaturamentoArrecadacaoExpurgo(anoMesreferencia,(String) getParametro("gerenciaRegional"),
(String) getParametro("unidadeNegocio"));
return retorno;
}
public void agendarTarefaBatch() {
AgendadorTarefas.agendarTarefa("RelatorioComparativoFatArrecExpurgado", this);
}
}