package gcom.relatorio.financeiro;
import gcom.batch.Relatorio;
import gcom.cadastro.geografico.FiltroMunicipio;
import gcom.cadastro.geografico.Municipio;
import gcom.cadastro.localidade.FiltroGerenciaRegional;
import gcom.cadastro.localidade.FiltroLocalidade;
import gcom.cadastro.localidade.FiltroUnidadeNegocio;
import gcom.cadastro.localidade.GerenciaRegional;
import gcom.cadastro.localidade.Localidade;
import gcom.cadastro.localidade.UnidadeNegocio;
import gcom.cadastro.sistemaparametro.SistemaParametro;
import gcom.fachada.Fachada;
import gcom.gui.ActionServletException;
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.filtro.ParametroSimples;
import java.util.Collection;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class RelatorioSaldoContasAReceberContabil extends TarefaRelatorio {
private static final long serialVersionUID = 1L;
public RelatorioSaldoContasAReceberContabil (Usuario usuario) {
super(usuario,ConstantesRelatorios.RELATORIO_SALDO_CONTAS_A_RECEBER_CONTABIL);
}
@SuppressWarnings("unchecked")
public Object executar() throws TarefaException {
// ------------------------------------
Integer idFuncionalidadeIniciada = this.getIdFuncionalidadeIniciada();
// ------------------------------------
String opcaoTotalizacao = (String) getParametro("opcaoTotalizacao");
int mesAno = (Integer) getParametro("mesAnoInteger");
Integer codigoLocalidade = (Integer) getParametro("localidade");
Integer codigoMunicipio = (Integer) getParametro("municipio");
Integer codigoGerencia = (Integer) getParametro("gerenciaRegional");
Integer unidadeNegocio = (Integer) getParametro("unidadeNegocio");
int tipoFormatoRelatorio = (Integer) getParametro("tipoFormatoRelatorio");
// valor de retorno
byte[] retorno = null;
// Par�metros do relat�rio
Map parametros = new HashMap();
Fachada fachada = Fachada.getInstancia();
Collection<RelatorioSaldoContasAReceberContabilBean> colecaoBean = fachada
.consultarDadosRelatorioSaldoContasAReceberContabil(opcaoTotalizacao, mesAno,
codigoGerencia, unidadeNegocio, codigoLocalidade, codigoMunicipio);
if (colecaoBean == null || colecaoBean.isEmpty()) {
// N�o existem dados para a exibi��o do relat�rio.
throw new RelatorioVazioException("atencao.relatorio.vazio");
} else {
Collections.sort((List) colecaoBean, new Comparator() {
public int compare(Object a, Object b) {
if (a == null) {
return 1;
} else if (b == null){
return -1;
}
if (a instanceof RelatorioSaldoContasAReceberContabilBean &&
b instanceof RelatorioSaldoContasAReceberContabilBean){
RelatorioSaldoContasAReceberContabilBean bean1 =
(RelatorioSaldoContasAReceberContabilBean) a;
RelatorioSaldoContasAReceberContabilBean bean2 =
(RelatorioSaldoContasAReceberContabilBean) b;
int comparacao = 0;
// Primeira classificacao sera por centro de custo (caso a opcao de totalizacao seja Localidade)
// como nos demais casos os valores de centro de custo sera todos 0, n�o ter� influencia
comparacao = bean1.getCodigoCentroCusto().compareTo(bean2.getCodigoCentroCusto());
if (comparacao != 0){
return comparacao;
}
// Classifica��o do relat�rio ser� pelo Id do grupo (Gerencia, UN, Localidade, etc)
comparacao = bean1.getIdGrupo().compareTo(bean2.getIdGrupo());
if (comparacao != 0){
return comparacao;
}
comparacao = bean1.getSequenciaLancamentoTipo() - bean2.getSequenciaLancamentoTipo();
if (comparacao == 0){
comparacao = bean1.getSequenciaLancamentoItem() - bean2.getSequenciaLancamentoItem();
}
return comparacao;
} else {
return 0;
}
}
});
}
//Montando o TOTAL DO CONTAS A RECEBER
int tamanhoColecao = colecaoBean.size();
int count = 2;
boolean achouPenultimoLancTipo = false;
Object[] colecao = colecaoBean.toArray();
RelatorioSaldoContasAReceberContabilBean relatorioPenultimo = null;
//Procura qual o ultimo tipo de lan�amento sem ser o DEDU��ES DO CONTAS A RECEBER
while (achouPenultimoLancTipo == false){
relatorioPenultimo = (RelatorioSaldoContasAReceberContabilBean) colecao[tamanhoColecao-count];
if (!relatorioPenultimo.getIdLancamentoTipo().toString().equals("52")){
achouPenultimoLancTipo = true;
}
count++;
}
//Atribui os valores dos totais do TOTAL DO CONTAS A RECEBER para a primeira cole��o do DEDUCOES
RelatorioSaldoContasAReceberContabilBean relatorioUltimo = (RelatorioSaldoContasAReceberContabilBean) colecao[tamanhoColecao-count+2];
relatorioUltimo.setTotalGeralSemPerdas(relatorioPenultimo.getTotalGeralSemPerdas());
relatorioUltimo.setTotalGeralSemPerdasComercial(relatorioPenultimo.getTotalGeralSemPerdasComercial());
relatorioUltimo.setTotalGeralSemPerdasIndustrial(relatorioPenultimo.getTotalGeralSemPerdasIndustrial());
relatorioUltimo.setTotalGeralSemPerdasParticular(relatorioPenultimo.getTotalGeralSemPerdasParticular());
relatorioUltimo.setTotalGeralSemPerdasPublico(relatorioPenultimo.getTotalGeralSemPerdasPublico());
relatorioUltimo.setTotalGeralSemPerdasResidencial(relatorioPenultimo.getTotalGeralSemPerdasResidencial());
//FIM
String opcaoTotalizacaoDesc = "";
if (opcaoTotalizacao.equalsIgnoreCase("estado")) {
opcaoTotalizacaoDesc = "Estado";
} else if (opcaoTotalizacao.equalsIgnoreCase("estadoGerencia")) {
opcaoTotalizacaoDesc = "Estado por Ger�ncia Regional";
} else if (opcaoTotalizacao.equalsIgnoreCase("estadoLocalidade")) {
opcaoTotalizacaoDesc = "Estado por Localidade";
} else if (opcaoTotalizacao.equalsIgnoreCase("estadoMunicipio")) {
opcaoTotalizacaoDesc = "Estado por Munic�pio";
} else if (opcaoTotalizacao.equalsIgnoreCase("gerenciaRegional")) {
GerenciaRegional gerencia = pesquisarGerenciaRegional(codigoGerencia);
if (gerencia != null){
opcaoTotalizacaoDesc = "Ger�ncia Regional ("+ codigoGerencia + "-" + gerencia.getNome() + ")";
} else {
opcaoTotalizacaoDesc = "Ger�ncia Regional";
}
} else if (opcaoTotalizacao
.equalsIgnoreCase("gerenciaRegionalLocalidade")) {
GerenciaRegional gerencia = pesquisarGerenciaRegional(codigoGerencia);
if (gerencia != null){
opcaoTotalizacaoDesc = "Ger�ncia Regional (" + codigoGerencia + "-" + gerencia.getNome() + ") por Localidade";
} else {
opcaoTotalizacaoDesc = "Ger�ncia Regional por Localidade";
}
} else if (opcaoTotalizacao
.equalsIgnoreCase("gerenciaRegionalUnidadeNegocio")) {
GerenciaRegional gerencia = pesquisarGerenciaRegional(codigoGerencia);
if (gerencia != null){
opcaoTotalizacaoDesc = "Ger�ncia Regional ("+ codigoGerencia + "-" + gerencia.getNome() + ") por Unidade de Neg�cio";
} else {
opcaoTotalizacaoDesc = "Ger�ncia Regional por Unidade de Neg�cio";
}
} else if (opcaoTotalizacao.equalsIgnoreCase("localidade")) {
Localidade localidade = pesquisarLocalidade(codigoLocalidade);
if (localidade != null){
opcaoTotalizacaoDesc = "Localidade ("+ codigoLocalidade + "-" + localidade.getDescricao() + ") ";
} else {
opcaoTotalizacaoDesc = "Localidade";
}
} else if (opcaoTotalizacao.equalsIgnoreCase("municipio")) {
Municipio municipio = pesquisarMunicipio(codigoMunicipio);
if (municipio != null){
opcaoTotalizacaoDesc = "Munic�pio ("+ codigoMunicipio + "-" + municipio.getNome() + ") ";
} else {
opcaoTotalizacaoDesc = "Munic�pio";
}
} else if (opcaoTotalizacao.equals("estadoUnidadeNegocio")) {
opcaoTotalizacaoDesc = "Estado por Unidade de Neg�cio";
} else if (opcaoTotalizacao.equals("unidadeNegocio")) {
UnidadeNegocio unidNegocio = pesquisarUnidadeNegocio(unidadeNegocio);
if (unidNegocio != null){
opcaoTotalizacaoDesc = "Unidade de Neg�cio (" + unidadeNegocio + "-" + unidNegocio.getNome() + ") ";
} else {
opcaoTotalizacaoDesc = "Unidade de Neg�cio";
}
} else if (opcaoTotalizacao.equals("unidadeNegocioLocalidade")) {
UnidadeNegocio unidNegocio = pesquisarUnidadeNegocio(unidadeNegocio);
if (unidNegocio != null){
opcaoTotalizacaoDesc = "Unidade de Neg�cio (" + unidadeNegocio + "-" + unidNegocio.getNome() + ") por Localidade";
} else {
opcaoTotalizacaoDesc = "Unidade de Neg�cio por Localidade";
}
}
parametros.put("opcaoTotalizacaoDesc", opcaoTotalizacaoDesc);
String mesAnoString = "" + mesAno;
if (mesAnoString.length() == 5) {
mesAnoString = "0" + mesAnoString;
}
mesAnoString = mesAnoString.substring(0, 2) + "/"
+ mesAnoString.substring(2, 6);
parametros.put("mesAnoReferencia", mesAnoString);
parametros.put("tipoFormatoRelatorio", "R0717");
SistemaParametro sistemaParametro = fachada.pesquisarParametrosDoSistema();
parametros.put("imagem", sistemaParametro.getImagemRelatorio());
RelatorioDataSource ds = new RelatorioDataSource((List) colecaoBean);
retorno = this.gerarRelatorio(
ConstantesRelatorios.RELATORIO_SALDO_CONTAS_A_RECEBER_CONTABIL, parametros,
ds, tipoFormatoRelatorio);
// ------------------------------------
// Grava o relat�rio no sistema
try {
persistirRelatorioConcluido(retorno, Relatorio.SALDO_CONTAS_A_RECEBER_CONTABIL,
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() {
// Fachada fachada = Fachada.getInstancia();
// String opcaoTotalizacao = (String) getParametro("opcaoTotalizacao");
// int mesAno = (Integer) getParametro("mesAnoInteger");
// Integer idLocalidade = (Integer) getParametro("localidade");
// Integer idGerencia = (Integer) getParametro("gerenciaRegional");
//
// Integer totalRegistrosRel;
// totalRegistrosRel = fachada
// .consultarQtdeRegistrosResumoFaturamentoRelatorio(mesAno, idLocalidade,
// idGerencia, opcaoTotalizacao);
return 1;//totalRegistrosRel.intValue();
}
public void agendarTarefaBatch() {
}
private GerenciaRegional pesquisarGerenciaRegional(Integer idGerencia) {
if (idGerencia == null){
return null;
}
Fachada fachada = Fachada.getInstancia();
// Pesquisa a localidade na base
FiltroGerenciaRegional filtroGerencia = new FiltroGerenciaRegional();
filtroGerencia.adicionarParametro(new ParametroSimples(
FiltroGerenciaRegional.ID, idGerencia));
Collection<GerenciaRegional> gerenciaPesquisada = fachada.pesquisar(
filtroGerencia, GerenciaRegional.class.getName());
if (gerenciaPesquisada == null || gerenciaPesquisada.isEmpty()) {
// a localidade n�o foi encontrada
throw new ActionServletException("atencao.gerenciaregional.inexistente");
}
return (GerenciaRegional) Util.retonarObjetoDeColecao(gerenciaPesquisada);
}
private Localidade pesquisarLocalidade(Integer idLocalidade) {
if (idLocalidade == null){
return null;
}
Fachada fachada = Fachada.getInstancia();
// Pesquisa a localidade na base
FiltroLocalidade filtroLocalidade = new FiltroLocalidade();
filtroLocalidade.adicionarParametro(new ParametroSimples(
FiltroLocalidade.ID, idLocalidade));
Collection<Localidade> localidadePesquisada = fachada.pesquisar(
filtroLocalidade, Localidade.class.getName());
if (localidadePesquisada == null || localidadePesquisada.isEmpty()) {
// a localidade n�o foi encontrada
throw new ActionServletException("atencao.localidade.inexistente");
}
return (Localidade) Util.retonarObjetoDeColecao(localidadePesquisada);
}
private Municipio pesquisarMunicipio(Integer idMunicipio) {
if (idMunicipio == null){
return null;
}
Fachada fachada = Fachada.getInstancia();
// Pesquisa a localidade na base
FiltroMunicipio filtroMunicipio = new FiltroMunicipio();
filtroMunicipio.adicionarParametro(new ParametroSimples(
FiltroMunicipio.ID, idMunicipio));
Collection<Municipio> municipioPesquisado = fachada.pesquisar(
filtroMunicipio, Municipio.class.getName());
if (municipioPesquisado == null || municipioPesquisado.isEmpty()) {
// a localidade n�o foi encontrada
throw new ActionServletException("atencao.localidade.inexistente");
}
return (Municipio) Util.retonarObjetoDeColecao(municipioPesquisado);
}
private UnidadeNegocio pesquisarUnidadeNegocio(Integer idUnidadeNegocio) {
if (idUnidadeNegocio == null){
return null;
}
Fachada fachada = Fachada.getInstancia();
// Pesquisa a localidade na base
FiltroUnidadeNegocio filtroUN = new FiltroUnidadeNegocio();
filtroUN.adicionarParametro(new ParametroSimples(
FiltroUnidadeNegocio.ID, idUnidadeNegocio));
Collection<UnidadeNegocio> UNPesquisada = fachada.pesquisar(
filtroUN, UnidadeNegocio.class.getName());
if (UNPesquisada == null || UNPesquisada.isEmpty()) {
// a localidade n�o foi encontrada
throw new ActionServletException("atencao.unidadenegocio.inexistente");
}
return (UnidadeNegocio) Util.retonarObjetoDeColecao(UNPesquisada);
}
}