package gcom.relatorio.cadastro.localidade;
import gcom.batch.Relatorio;
import gcom.cadastro.localidade.FiltroSetorComercial;
import gcom.cadastro.localidade.SetorComercial;
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.agendadortarefas.AgendadorTarefas;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
/**
* <p>
* Title: GCOM
* </p>
* <p>
* Description: Sistema de Gest�o Comercial
* </p>
* <p>
* Copyright: Copyright (c) 2004
* </p>
* <p>
* Company: COMPESA - Companhia Pernambucana de Saneamento
* </p>
*
* @author not attributable
* @version 1.0
*/
public class RelatorioManterSetorComercial extends TarefaRelatorio {
private static final long serialVersionUID = 1L;
public RelatorioManterSetorComercial(Usuario usuario) {
super(usuario, ConstantesRelatorios.RELATORIO_SETOR_COMERCIAL_MANTER);
}
@Deprecated
public RelatorioManterSetorComercial() {
super(null, "");
}
/**
* < <Descri��o do m�todo>>
*
* @param setoresComerciais
* Description of the Parameter
* @param setorComercialParametros
* Description of the Parameter
* @return Descri��o do retorno
* @exception RelatorioVazioException
* Descri��o da exce��o
*/
public Object executar() throws TarefaException {
// ------------------------------------
Integer idFuncionalidadeIniciada = this.getIdFuncionalidadeIniciada();
// ------------------------------------
FiltroSetorComercial filtroSetorComercial = (FiltroSetorComercial) getParametro("filtroSetorComercial");
SetorComercial setorComercialParametros = (SetorComercial) getParametro("setorComercialParametros");
int tipoFormatoRelatorio = (Integer) getParametro("tipoFormatoRelatorio");
// valor de retorno
byte[] retorno = null;
Fachada fachada = Fachada.getInstancia();
// cole��o de beans do relat�rio
List relatorioBeans = new ArrayList();
RelatorioManterSetorComercialBean relatorioBean = null;
filtroSetorComercial
.adicionarCaminhoParaCarregamentoEntidade("localidade");
filtroSetorComercial
.adicionarCaminhoParaCarregamentoEntidade("municipio");
filtroSetorComercial.setConsultaSemLimites(true);
Collection setoresComerciais = fachada.pesquisar(filtroSetorComercial,
SetorComercial.class.getName());
// se a cole��o de par�metros da analise n�o for vazia
if (setoresComerciais != null && !setoresComerciais.isEmpty()) {
// Organizar a cole��o
Collections.sort((List) setoresComerciais, new Comparator() {
public int compare(Object a, Object b) {
String localidade1 = ((SetorComercial) a).getLocalidade()
.getDescricao();
String localidade2 = ((SetorComercial) b).getLocalidade()
.getDescricao();
return localidade1.compareTo(localidade2);
}
});
// coloca a cole��o de par�metros da analise no iterator
Iterator setorComercialIterator = setoresComerciais.iterator();
// la�o para criar a cole��o de par�metros da analise
while (setorComercialIterator.hasNext()) {
SetorComercial setorComercial = (SetorComercial) setorComercialIterator
.next();
relatorioBean = new RelatorioManterSetorComercialBean(
// Localidade
setorComercial.getLocalidade().getDescricao(),
// C�digo
"" + setorComercial.getCodigo(),
// Descri��o
setorComercial.getDescricao(),
// Munic�pio
setorComercial.getMunicipio()
.getNome(),
// Indicador Uso
setorComercial.getIndicadorUso().toString());
// adiciona o bean a cole��o
relatorioBeans.add(relatorioBean);
}
}
// 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("codigo", setorComercialParametros.getCodigo() == 0 ? ""
: "" + setorComercialParametros.getCodigo());
parametros.put("nome", setorComercialParametros.getDescricao());
parametros.put("idLocalidade", setorComercialParametros.getLocalidade()
.getId() == null ? "" : ""
+ setorComercialParametros.getLocalidade().getId());
parametros.put("nomeLocalidade", setorComercialParametros
.getLocalidade().getDescricao());
parametros.put("idMunicipio", setorComercialParametros.getMunicipio()
.getId() == null ? "" : ""
+ setorComercialParametros.getMunicipio().getId());
parametros.put("nomeMunicipio", setorComercialParametros.getMunicipio()
.getNome());
String indicadorUso = "";
if (setorComercialParametros.getIndicadorUso() != null
&& !setorComercialParametros.getIndicadorUso().equals("")) {
if (setorComercialParametros.getIndicadorUso().equals(
new Short("1"))) {
indicadorUso = "Ativo";
} else if (setorComercialParametros.getIndicadorUso().equals(
new Short("2"))) {
indicadorUso = "Inativo";
}
}
parametros.put("indicadorUso", indicadorUso);
// cria uma inst�ncia do dataSource do relat�rio
RelatorioDataSource ds = new RelatorioDataSource(relatorioBeans);
retorno = this.gerarRelatorio(
ConstantesRelatorios.RELATORIO_SETOR_COMERCIAL_MANTER,
parametros, ds, tipoFormatoRelatorio);
// ------------------------------------
// Grava o relat�rio no sistema
try {
persistirRelatorioConcluido(retorno, Relatorio.MANTER_SETOR_COMERCIAL,
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() {
int retorno = 0;
retorno = Fachada.getInstancia().totalRegistrosPesquisa(
(FiltroSetorComercial) getParametro("filtroSetorComercial"),
SetorComercial.class.getName());
return retorno;
}
public void agendarTarefaBatch() {
AgendadorTarefas.agendarTarefa("RelatorioManterSetorComercial", this);
}
}