package gcom.gui.relatorio.faturamento; import gcom.faturamento.FaturamentoGrupo; import gcom.micromedicao.medicao.FiltroMedicaoHistoricoSql; import gcom.relatorio.ExibidorProcessamentoTarefaRelatorio; import gcom.relatorio.RelatorioVazioException; import gcom.relatorio.faturamento.RelatorioFaturamentoLigacoesMedicaoIndividualizada; import gcom.seguranca.acesso.usuario.Usuario; import gcom.tarefa.TarefaRelatorio; import gcom.util.Util; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import org.apache.struts.action.ActionForm; import org.apache.struts.action.ActionForward; import org.apache.struts.action.ActionMapping; /** * [UC0532] Gerar Relat�rio de Faturamento das Liga��es com Medi��o Individualizada * * @author Vivianne Sousa * @date 09/01/2007 */ public class GerarRelatorioFaturamentoLigacoesMedicaoIndividualizadaAction extends ExibidorProcessamentoTarefaRelatorio { public ActionForward execute(ActionMapping actionMapping, ActionForm actionForm, HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) { ActionForward retorno = null; HttpSession sessao = httpServletRequest.getSession(false); FiltroMedicaoHistoricoSql filtroMedicaoHistoricoSql = new FiltroMedicaoHistoricoSql(); FaturamentoGrupo faturamentoGrupo = (FaturamentoGrupo)sessao.getAttribute("faturamentoGrupo"); String mesAnoPesquisa = (String) sessao.getAttribute("mesAnoPesquisa"); if (sessao.getAttribute("filtroMedicaoHistoricoSql") != null) { filtroMedicaoHistoricoSql = (FiltroMedicaoHistoricoSql) sessao.getAttribute("filtroMedicaoHistoricoSql"); } // Collection colecaoFaturamentoLigacoesMedicaoIndividualizadaHelper = null; // // if (colecaoImoveisGerarRelatorio != null // && !colecaoImoveisGerarRelatorio.isEmpty()) { // fachada // .pesquisarFaturamentoLigacoesMedicaoIndividualizadaRelatorio( // colecaoImoveisGerarRelatorio, "" // + faturamentoGrupo.getAnoMesReferencia()); // } else { // fachada // .pesquisarFaturamentoLigacoesMedicaoIndividualizadaRelatorio( // filtroMedicaoHistoricoSql, "" // + faturamentoGrupo.getAnoMesReferencia()); // } // Parte que vai mandar o relat�rio para a tela // cria uma inst�ncia da classe do relat�rio RelatorioFaturamentoLigacoesMedicaoIndividualizada relatorioFaturamentoLigacoesMedicaoIndividualizada = new RelatorioFaturamentoLigacoesMedicaoIndividualizada((Usuario)(httpServletRequest.getSession(false)).getAttribute("usuarioLogado")); // relatorioFaturamentoLigacoesMedicaoIndividualizada.addParametro("colecaoFaturamentoLigacoesMedicaoIndividualizadaHelper",colecaoFaturamentoLigacoesMedicaoIndividualizadaHelper); String tipoRelatorio = httpServletRequest.getParameter("tipoRelatorio"); if (tipoRelatorio == null) { tipoRelatorio = TarefaRelatorio.TIPO_PDF + ""; } relatorioFaturamentoLigacoesMedicaoIndividualizada.addParametro("tipoFormatoRelatorio", Integer.parseInt(tipoRelatorio)); relatorioFaturamentoLigacoesMedicaoIndividualizada.addParametro("anoMesFaturamentoGrupo" ,Util.formatarAnoMesParaMesAno(faturamentoGrupo.getAnoMesReferencia())); relatorioFaturamentoLigacoesMedicaoIndividualizada.addParametro("idGrupoFaturamento","" + faturamentoGrupo.getId()); relatorioFaturamentoLigacoesMedicaoIndividualizada.addParametro("faturamentoGrupo",faturamentoGrupo); relatorioFaturamentoLigacoesMedicaoIndividualizada.addParametro("filtroMedicaoHistoricoSql",filtroMedicaoHistoricoSql); relatorioFaturamentoLigacoesMedicaoIndividualizada.addParametro("mesAnoPesquisa",mesAnoPesquisa); try { retorno = processarExibicaoRelatorio(relatorioFaturamentoLigacoesMedicaoIndividualizada, tipoRelatorio, httpServletRequest, httpServletResponse, actionMapping); } catch (RelatorioVazioException ex) { // manda o erro para a p�gina no request atual reportarErros(httpServletRequest, "atencao.relatorio.vazio"); // seta o mapeamento de retorno para a tela de aten��o de popup retorno = actionMapping.findForward("telaAtencaoPopup"); } return retorno; } }