package gcom.relatorio.arrecadacao;
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;
import gcom.arrecadacao.bean.FiltrarDadosDiariosArrecadacaoHelper;
import gcom.cadastro.sistemaparametro.FiltroSistemaParametro;
import gcom.cadastro.sistemaparametro.SistemaParametro;
import gcom.cobranca.DocumentoTipo;
import gcom.fachada.Fachada;
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.Util;
import gcom.util.agendadortarefas.AgendadorTarefas;
/**
* [UC0339] Consultar Dados Di�rios da Arrecada��o
*
* Gerar Relat�rio Dados Di�rios da Arrecada��o - Documento Agregador
*
* @author Mariana Victor
* @date 04/02/2011
*/
public class RelatorioDadosDiariosDocumentoAgregador extends TarefaRelatorio {
private static final long serialVersionUID = 1L;
public RelatorioDadosDiariosDocumentoAgregador(Usuario usuario) {
super(usuario, ConstantesRelatorios.RELATORIO_RELATORIO_DADOS_DIARIOS_DOCUMENTO_AGREGADOR_POPUP);
}
/**
* M�todo que executa a tarefa
*
* @return Object
*/
public Object executar() throws TarefaException {
// valor de retorno
byte[] retorno = null;
Fachada fachada = Fachada.getInstancia();
int tipoFormatoRelatorio = (Integer) getParametro("tipoFormatoRelatorio");
String nomeArrecadador = (String) getParametro("arrecadador");
BigDecimal valorTotal = null;
String referencia = null;
String dadosMesInformado = null;
String dadosAtual = null;
String descricaoDocumentoTipoAgregador = null;
String faturamentoCobradoEmConta = null;
Collection<FiltrarDadosDiariosArrecadacaoHelper> colecaoDadosDiarios = null;
if (getParametro("valorTotal") != null) {
valorTotal = (BigDecimal) getParametro("valorTotal");
}
if (getParametro("referencia") != null) {
referencia = (String) getParametro("referencia");
}
if (getParametro("dadosMesInformado") != null) {
dadosMesInformado = (String) getParametro("dadosMesInformado");
}
if (getParametro("dadosAtual") != null) {
dadosAtual = (String) getParametro("dadosAtual");
}
if (getParametro("descricaoDocumentoTipoAgregador") != null) {
descricaoDocumentoTipoAgregador = (String) getParametro("descricaoDocumentoTipoAgregador");
}
if (getParametro("faturamentoCobradoEmConta") != null) {
faturamentoCobradoEmConta = (String) getParametro("faturamentoCobradoEmConta");
}
if (getParametro("colecaoDadosDiarios") != null) {
colecaoDadosDiarios = (Collection<FiltrarDadosDiariosArrecadacaoHelper>) getParametro("colecaoDadosDiarios");
}
// Par�metros do relat�rio
Map parametros = new HashMap();
FiltroSistemaParametro filtroSistemaParametro = new FiltroSistemaParametro();
filtroSistemaParametro.adicionarCaminhoParaCarregamentoEntidade("bairro");
filtroSistemaParametro.adicionarCaminhoParaCarregamentoEntidade("enderecoReferencia");
filtroSistemaParametro.adicionarCaminhoParaCarregamentoEntidade("logradouroBairro");
filtroSistemaParametro.adicionarCaminhoParaCarregamentoEntidade("logradouroCep");
filtroSistemaParametro.adicionarCaminhoParaCarregamentoEntidade("logradouroCep.logradouro.logradouroTipo");
filtroSistemaParametro.adicionarCaminhoParaCarregamentoEntidade("logradouroCep.logradouro.logradouroTitulo");
filtroSistemaParametro.adicionarCaminhoParaCarregamentoEntidade("logradouroCep.cep");
filtroSistemaParametro.adicionarCaminhoParaCarregamentoEntidade("logradouroBairro.bairro.municipio.unidadeFederacao");
filtroSistemaParametro.adicionarCaminhoParaCarregamentoEntidade("cep");
Collection colecaoSistemaParametro = fachada.pesquisar(filtroSistemaParametro,SistemaParametro.class.getName());
SistemaParametro sistemaParametro = (SistemaParametro) colecaoSistemaParametro.iterator().next();
String cnpjEmpresa = "";
if (sistemaParametro.getCnpjEmpresa() != null) {
cnpjEmpresa = Util.formatarCnpj(sistemaParametro.getCnpjEmpresa());
}
String arrecadador = "";
if (nomeArrecadador != null){
if(nomeArrecadador.equals("")){
arrecadador = "TODOS";
}
else{
arrecadador = nomeArrecadador;
}
}
// Usuario que emite o relatorio
Usuario usuario = this.getUsuario();
String nomeUsuario = usuario.getNomeUsuario();
parametros.put("nomeUsuario", nomeUsuario);
parametros.put("nomeEmpresa",sistemaParametro.getNomeAbreviadoEmpresa());
parametros.put("cnpjEmpresa", cnpjEmpresa);
parametros.put("imagem", sistemaParametro.getImagemRelatorio());
parametros.put("enderecoEmpresa", sistemaParametro.getEnderecoFormatado());
parametros.put("cepEmpresa", sistemaParametro.getCep().getCepFormatado());
parametros.put("telefoneGeral", sistemaParametro.getNumeroTelefone());
parametros.put("arrecadador", arrecadador);
Collection<RelatorioDadosDiariosDocumentoAgregadorBean> colecaoBean = this
.inicializarBeanRelatorio(valorTotal, referencia, dadosMesInformado,
dadosAtual, descricaoDocumentoTipoAgregador, faturamentoCobradoEmConta, colecaoDadosDiarios);
RelatorioDataSource ds = new RelatorioDataSource((List) colecaoBean);
retorno = this
.gerarRelatorio(
ConstantesRelatorios.RELATORIO_RELATORIO_DADOS_DIARIOS_DOCUMENTO_AGREGADOR_POPUP,
parametros, ds, tipoFormatoRelatorio);
// retorna o relat�rio gerado
return retorno;
}
@Override
public int calcularTotalRegistrosRelatorio() {
int retorno = 0;
return retorno;
}
@Override
public void agendarTarefaBatch() {
AgendadorTarefas.agendarTarefa("RelatorioDadosDiariosDocumentoAgregador", this);
}
private Collection<RelatorioDadosDiariosDocumentoAgregadorBean> inicializarBeanRelatorio(
BigDecimal valorTotal, String referencia, String dadosMesInformado,
String dadosAtual, String descricaoDocumentoTipoAgregador, String faturamentoCobradoEmConta,
Collection<FiltrarDadosDiariosArrecadacaoHelper> colecaoDadosDiarios){
Collection<RelatorioDadosDiariosDocumentoAgregadorBean> colecaoBean = new ArrayList<RelatorioDadosDiariosDocumentoAgregadorBean>();
if (colecaoDadosDiarios != null && !colecaoDadosDiarios.isEmpty()){
Iterator iterator = colecaoDadosDiarios.iterator();
while (iterator.hasNext()) {
FiltrarDadosDiariosArrecadacaoHelper itemHelper = (FiltrarDadosDiariosArrecadacaoHelper) iterator.next();
RelatorioDadosDiariosDocumentoAgregadorBean bean = new RelatorioDadosDiariosDocumentoAgregadorBean();
DocumentoTipo documentoTipo = (DocumentoTipo) itemHelper.getItemAgrupado();
bean.setProcessamentoDefinitivo(dadosMesInformado);
bean.setMesAno(Util.formatarAnoMesParaMesAno(referencia));
bean.setUltimoProcessamentoAtual(dadosAtual);
bean.setFaturamentoCobradoEmConta(faturamentoCobradoEmConta);
bean.setDocumentoAgregador(descricaoDocumentoTipoAgregador);
bean.setValor(Util.formatarMoedaReal(valorTotal));
bean.setTipo(documentoTipo.getDescricaoDocumentoTipo());
bean.setQuantidadePagamentos(Util.agruparNumeroEmMilhares(itemHelper.getQuantidadePagamentos()));
bean.setDebitos(Util.formatarMoedaReal(itemHelper.getValorDebitos()));
bean.setDescontos(Util.formatarMoedaReal(itemHelper.getValorDescontos()));
bean.setValorArrecadado(Util.formatarMoedaReal(itemHelper.getValorArrecadacao()));
bean.setDevolucao(Util.formatarMoedaReal(itemHelper.getValorDevolucoes()));
bean.setArrecadacaoLiquida(Util.formatarMoedaReal(itemHelper.getValorArrecadacaoLiquida()));
bean.setPercentualMes(Util.formatarMoedaReal(itemHelper.getPercentual()));
colecaoBean.add(bean);
}
}
return colecaoBean;
}
}