/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package mx.edu.um.mateo.colportor.web;
import java.io.BufferedOutputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.*;
import javax.mail.MessagingException;
import javax.mail.internet.MimeMessage;
import javax.mail.util.ByteArrayDataSource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
import mx.edu.um.mateo.general.utils.Constantes;
import mx.edu.um.mateo.colportor.dao.ColportorDao;
import mx.edu.um.mateo.colportor.dao.DocumentoDao;
import mx.edu.um.mateo.colportor.dao.TemporadaColportorDao;
import mx.edu.um.mateo.colportor.dao.TemporadaDao;
import mx.edu.um.mateo.colportor.model.Colportor;
import mx.edu.um.mateo.colportor.model.Documento;
import mx.edu.um.mateo.colportor.model.Temporada;
import mx.edu.um.mateo.colportor.model.TemporadaColportor;
import mx.edu.um.mateo.general.model.*;
import mx.edu.um.mateo.general.utils.Ambiente;
import mx.edu.um.mateo.general.utils.LabelValueBean;
import mx.edu.um.mateo.general.web.BaseController;
import net.sf.jasperreports.engine.*;
import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;
import net.sf.jasperreports.engine.design.JasperDesign;
import net.sf.jasperreports.engine.export.JRCsvExporter;
import net.sf.jasperreports.engine.export.JRXlsExporter;
import net.sf.jasperreports.engine.export.JRXlsExporterParameter;
import net.sf.jasperreports.engine.xml.JRXmlLoader;
import org.apache.commons.lang.StringUtils;
import org.hibernate.exception.ConstraintViolationException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.support.ResourceBundleMessageSource;
import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.mail.javamail.MimeMessageHelper;
import org.springframework.stereotype.Controller;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.ui.Model;
import org.springframework.validation.BindingResult;
import org.springframework.validation.Errors;
import org.springframework.validation.ObjectError;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.servlet.mvc.support.RedirectAttributes;
/**
*
* @author wilbert S
*/
@Controller
@RequestMapping(Constantes.DOCUMENTOCOLPORTOR_PATH)
public class DocumentoController extends BaseController {
private static final Logger log = LoggerFactory.getLogger(DocumentoController.class);
@Autowired
private DocumentoDao DocumentoDao;
@Autowired
private JavaMailSender mailSender;
@Autowired
private ResourceBundleMessageSource messageSource;
@Autowired
private Ambiente ambiente;
@Autowired
private TemporadaColportorDao temporadaColportorDao;
@Autowired
private ColportorDao colportorDao;
@Autowired
private TemporadaDao temporadaDao;
/*
* DE AQUI @InitBinder public void initBinder(WebDataBinder binder) {
*
* binder.registerCustomEditor(TipoDocumento.class, new
* EnumEditor(TipoDocumento.class)); }
*/
@RequestMapping({"/lista", ""})
public String lista(HttpServletRequest request, HttpServletResponse response,
@RequestParam(required = false) String filtro,
@RequestParam(required = false) Long pagina,
@RequestParam(required = false) String tipo,
@RequestParam(required = false) String correo,
@RequestParam(required = false) String order,
@RequestParam(required = false) String sort,
@RequestParam(required = false) String clave,
@RequestParam(required = false) String temporadaId,
Usuario usuario,
Errors errors,
Model modelo) {
log.debug("Mostrando lista de documentos");
Map<String, Object> params = new HashMap<>();
params.put("organizacion", ambiente.obtieneUsuario().getEmpresa().getOrganizacion().getId());
params.put("empresa", ambiente.obtieneUsuario().getEmpresa().getId());
params.put("asociado", ambiente.obtieneUsuario().getId());
Integer max = 100;
if (StringUtils.isNotBlank(filtro)) {
params.put(Constantes.CONTAINSKEY_FILTRO, filtro);
}
if (pagina != null) {
params.put(Constantes.CONTAINSKEY_PAGINA, pagina);
modelo.addAttribute(Constantes.CONTAINSKEY_PAGINA, pagina);
} else {
pagina = 1L;
modelo.addAttribute(Constantes.CONTAINSKEY_PAGINA, pagina);
}
params.put(Constantes.CONTAINSKEY_MAX, 100);
if (StringUtils.isNotBlank(order)) {
params.put(Constantes.CONTAINSKEY_ORDER, order);
params.put(Constantes.CONTAINSKEY_SORT, sort);
}
log.debug("esAsociado {}, esColportor {}, colportorTmp {}", new Object [] {ambiente.esAsociado(), ambiente.esColportor(), request.getSession().getAttribute("colportorTmp")});
TemporadaColportor temporadaColportor = null;
if (ambiente.esAsociado()) {
log.debug("Entrando a Documentos como Asociado");
log.debug("clave" + clave);
if(clave == null || clave.isEmpty()){
if(request.getSession().getAttribute(Constantes.TEMPORADACOLPORTOR) != null) {
clave = ((TemporadaColportor)request.getSession().getAttribute(Constantes.TEMPORADACOLPORTOR)).getColportor().getClave();
}
}
if (clave != null && !clave.isEmpty()) {
Colportor colportor = colportorDao.obtiene(clave);
if(colportor == null){
errors.reject("colportor.clave.missing");
return Constantes.DOCUMENTOCOLPORTOR_PATH_LISTA;
}
log.debug("Colportor {} ", colportor);
modelo.addAttribute(Constantes.COLPORTOR, colportor);
if(temporadaId != null && !temporadaId.isEmpty()){
log.debug("temporadaId {}", temporadaId);
log.debug("temporada {}", temporadaDao.obtiene(Long.valueOf(temporadaId)));
temporadaColportor = temporadaColportorDao.obtiene(colportor, temporadaDao.obtiene(Long.valueOf(temporadaId)));
}
else{
temporadaColportor = temporadaColportorDao.obtiene(colportor);
}
log.debug("Temporada Colportor {} ", temporadaColportor);
request.getSession().setAttribute(Constantes.TEMPORADACOLPORTOR, temporadaColportor);
modelo.addAttribute(Constantes.TEMPORADACOLPORTOR, temporadaColportor);
params.put("temporadaColportor", temporadaColportor.getId());
} else {
errors.reject("colportor.clave.missing");
return Constantes.DOCUMENTOCOLPORTOR_PATH_LISTA;
}
}
if (ambiente.esColportor()) {
log.debug("Entrando a Documentos como Colportor");
Colportor colportor = colportorDao.obtiene(ambiente.obtieneUsuario().getId());
log.debug("Usuario {}",ambiente.obtieneUsuario());
log.debug("Colportor {}",colportor);
log.debug("temporada.id {}",request.getParameter("temporada.id"));
if (request.getParameter("temporada.id") == null) {
log.debug("Entrando a Documentos como Colportor {} con Temporada Activa", colportor);
temporadaColportor = temporadaColportorDao.obtiene(colportor);
params.put("temporadaColportor", temporadaColportor.getId());
} else {
log.debug("Entrando a Documentos como Colportor con Temporada Inactiva");
Temporada temporada = temporadaDao.obtiene(Long.parseLong(request.getParameter("temporada.id")));
log.debug("temporada" + temporada.getId());
temporadaColportor = temporadaColportorDao.obtiene(colportor, temporada);
params.put("temporadaColportor", temporadaColportor.getId());
}
// Codigo para validar prueba
log.debug("temporadaColportorTmp" + temporadaColportor.getId());
request.setAttribute("temporadaColportorTmp", temporadaColportor);
modelo.addAttribute("temporadaColportorTmp", temporadaColportor);
log.debug("temporadaColportorTmpId" + temporadaColportor.getId());
modelo.addAttribute("temporadaColportorPrueba", temporadaColportor.getId().toString());
modelo.addAttribute(Constantes.COLPORTOR, colportor);
}
if (StringUtils.isNotBlank(tipo)) {
params.put(Constantes.CONTAINSKEY_REPORTE, true);
params = DocumentoDao.lista(params);
try {
generaReporte(tipo, (List<Documento>) params.get(Constantes.DOCUMENTOCOLPORTOR_LIST), response);
return null;
} catch (JRException | IOException e) {
log.error("No se pudo generar el reporte", e);
params.remove(Constantes.CONTAINSKEY_REPORTE);
//errors.reject("error.generar.reporte");
}
}
if (StringUtils.isNotBlank(correo)) {
params.put(Constantes.CONTAINSKEY_REPORTE, true);
params = DocumentoDao.lista(params);
params.remove(Constantes.CONTAINSKEY_REPORTE);
try {
enviaCorreo(correo, (List<Documento>) params.get(Constantes.DOCUMENTOCOLPORTOR_LIST), request);
modelo.addAttribute(Constantes.CONTAINSKEY_MESSAGE, "lista.enviada.message");
modelo.addAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{messageSource.getMessage("documento.lista.label", null, request.getLocale()), ambiente.obtieneUsuario().getUsername()});
} catch (JRException | MessagingException e) {
log.error("No se pudo enviar el reporte por correo", e);
}
}
List<Documento> lista = null;
params = DocumentoDao.lista(params);
modelo.addAttribute(Constantes.DOCUMENTOCOLPORTOR_LIST, params.get(Constantes.DOCUMENTOCOLPORTOR_LIST));
params.put("filtro", clave);
List <Temporada> tmps = new ArrayList <>();
params = temporadaColportorDao.listadoTemporadasPorColportor(params);
List <TemporadaColportor> tmpClps = (List)params.get(Constantes.TEMPORADACOLPORTOR_LIST);
for(TemporadaColportor tmpClp : tmpClps){
tmps.add(tmpClp.getTemporada());
}
modelo.addAttribute(Constantes.TEMPORADA_LIST, tmps);
lista = (List) params.get(Constantes.DOCUMENTOCOLPORTOR_LIST);
Iterator<Documento> iter = lista.iterator();
Documento doc = null;
BigDecimal totalBoletin = new BigDecimal("0");
BigDecimal totalDiezmos = new BigDecimal("0");
BigDecimal totalDepositos = new BigDecimal("0");
BigDecimal totalCompras = new BigDecimal("0");
BigDecimal objetivo = null;
try {
objetivo = new BigDecimal(temporadaColportor.getObjetivo());
} catch (NullPointerException e) {
log.error("La temporadaColportor {} no tienen objetivo", temporadaColportor);
objetivo = new BigDecimal("0");
}
BigDecimal fidelidad = new BigDecimal("0");
BigDecimal alcanzado = new BigDecimal("0");
while (iter.hasNext()) {
doc = iter.next();
switch (doc.getTipoDeDocumento()) {
case Constantes.BOLETIN: {
log.debug("{} importe {}", doc.getId(), doc.getImporte());
totalBoletin = totalBoletin.add(doc.getImporte());
log.debug("totalBoletin {}", totalBoletin);
break;
}
case Constantes.DIEZMO: {
log.debug("importe {}", doc.getImporte());
totalDiezmos = totalDiezmos.add(doc.getImporte());
log.debug("totalDiezmos {}", totalDiezmos);
break;
}
case Constantes.DEPOSITO_CAJA: {
log.debug("importe {}", doc.getImporte());
totalDepositos = totalDepositos.add(doc.getImporte());
log.debug("totalDepositos {}", totalDepositos);
break;
}
case Constantes.DEPOSITO_BANCO: {
log.debug("importe {}", doc.getImporte());
totalDepositos = totalDepositos.add(doc.getImporte());
log.debug("totalDepositos {}", totalDepositos);
break;
}
case Constantes.NOTAS_DE_COMPRA: {
log.debug("importe {}", doc.getImporte());
totalCompras = totalCompras.add(doc.getImporte());
log.debug("totalCompras {}", totalCompras);
break;
}
}
}
modelo.addAttribute(Constantes.TOTALBOLETIN, totalBoletin.setScale(2, BigDecimal.ROUND_HALF_EVEN));
modelo.addAttribute(Constantes.TOTALDIEZMOS, totalDiezmos.setScale(2, BigDecimal.ROUND_HALF_EVEN));
modelo.addAttribute(Constantes.TOTALDEPOSITOS, totalDepositos.setScale(2, BigDecimal.ROUND_HALF_EVEN));
modelo.addAttribute(Constantes.TOTALCOMPRAS, totalCompras.setScale(2, BigDecimal.ROUND_HALF_EVEN));
modelo.addAttribute(Constantes.OBJETIVO, objetivo.setScale(2, BigDecimal.ROUND_HALF_EVEN));
if (objetivo.compareTo(new BigDecimal("0")) > 0) {
log.debug("% alcanzado = [totalBoletin {} / objetivo {}] = {}", new Object []{totalBoletin, objetivo, totalBoletin.divide(objetivo, 6, RoundingMode.HALF_EVEN).multiply(new BigDecimal("100"))});
alcanzado = totalBoletin.divide(objetivo, 6, RoundingMode.HALF_EVEN);//.multiply(new BigDecimal("100"));
}
if (totalBoletin.compareTo(new BigDecimal("0")) > 0) {
log.debug("fidelidad = [totalDiezmos {} / totalBoletin {}] = {}");
fidelidad = totalDiezmos.divide(totalBoletin.movePointLeft(1), 6, RoundingMode.HALF_EVEN);//.multiply(new BigDecimal("100"));
}
modelo.addAttribute(Constantes.ALCANZADO, alcanzado.setScale(4, BigDecimal.ROUND_HALF_EVEN));
modelo.addAttribute(Constantes.FIDELIDAD, fidelidad.setScale(4, BigDecimal.ROUND_HALF_EVEN));
pagina = (Long) params.get("pagina");
this.pagina(params, modelo, Constantes.DOCUMENTOCOLPORTOR_LIST, pagina);
return Constantes.DOCUMENTOCOLPORTOR_PATH_LISTA;
}
@RequestMapping("/ver/{id}")
public String ver(@PathVariable Long id, Model modelo) {
log.debug("Mostrando documento {}", id);
Documento documento = DocumentoDao.obtiene(id);
log.debug("ver documento {} con id {}", documento, id);
modelo.addAttribute(Constantes.DOCUMENTOCOLPORTOR, documento);
return Constantes.DOCUMENTOCOLPORTOR_PATH_VER;
}
@RequestMapping("/nuevo")
public String nuevo(Model modelo) {
log.debug("Nuevo documento");
Documento documentos = new Documento();
modelo.addAttribute(Constantes.DOCUMENTOCOLPORTOR, documentos);
return Constantes.DOCUMENTOCOLPORTOR_PATH_NUEVO;
}
@Transactional
@RequestMapping(value = "/crea", method = RequestMethod.POST)
public String crea(HttpServletRequest request, HttpServletResponse response, @Valid Documento documento,
BindingResult bindingResult, Errors errors, Model modelo, RedirectAttributes redirectAttributes) throws ParseException {
Map<String, Object> params = new HashMap<>();
for (String folio : request.getParameterMap().keySet()) {
log.debug("Param: {} : {}", folio, request.getParameterMap().get(folio));
}
if (bindingResult.hasErrors()) {
log.debug("Hubo algun error en la forma, regresando");
despliegaBindingResultErrors(bindingResult);
return Constantes.DOCUMENTOCOLPORTOR_PATH_NUEVO;
}
switch (documento.getTipoDeDocumento()) {
case "0":
documento.setTipoDeDocumento(Constantes.DEPOSITO_CAJA);
break;
case "1":
documento.setTipoDeDocumento(Constantes.DEPOSITO_BANCO);
break;
case "2":
documento.setTipoDeDocumento(Constantes.DIEZMO);
break;
case "3":
documento.setTipoDeDocumento(Constantes.NOTAS_DE_COMPRA);
break;
case "4":
documento.setTipoDeDocumento(Constantes.BOLETIN);
break;
case "5":
documento.setTipoDeDocumento(Constantes.INFORME);
break;
}
try {
SimpleDateFormat sdf = new SimpleDateFormat(Constantes.DATE_SHORT_HUMAN_PATTERN);
documento.setFecha(sdf.parse(request.getParameter("fecha")));
} catch (ConstraintViolationException e) {
log.error("Fecha", e);
return Constantes.DOCUMENTOCOLPORTOR_PATH_NUEVO;
}
try {
log.debug("Documento Fecha" + documento.getFecha());
//294 y 305
TemporadaColportor temporadaColportorTmp = null;
if(ambiente.esColportor()){
temporadaColportorTmp = temporadaColportorDao.obtiene((Colportor) ambiente.obtieneUsuario());
}
else{
//Se requiere una clave de colportor
Colportor clp = colportorDao.obtiene(((TemporadaColportor)request.getSession().getAttribute(Constantes.TEMPORADACOLPORTOR)).getColportor().getClave());
Temporada tmp = temporadaDao.obtiene(((TemporadaColportor)request.getSession().getAttribute(Constantes.TEMPORADACOLPORTOR)).getTemporada().getId());
temporadaColportorTmp = temporadaColportorDao.obtiene(clp, tmp);
}
documento.setTemporadaColportor(temporadaColportorTmp);
documento = DocumentoDao.crea(documento);
} catch (ConstraintViolationException e) {
log.error("No se pudo crear el documento", e);
return Constantes.DOCUMENTOCOLPORTOR_PATH_NUEVO;
}
redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE, "documento.creado.message");
redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{documento.getFolio()});
return "redirect:" + Constantes.DOCUMENTOCOLPORTOR_PATH_VER+"/"+documento.getId();
}
@RequestMapping("/edita/{id}")
public String edita(@PathVariable Long id, Model modelo) {
log.debug("Editar documento {}", id);
Documento documentos = DocumentoDao.obtiene(id);
modelo.addAttribute(Constantes.DOCUMENTOCOLPORTOR, documentos);
return Constantes.DOCUMENTOCOLPORTOR_PATH_EDITA;
}
@Transactional
@RequestMapping(value = "/actualiza", method = RequestMethod.POST)
public String actualiza(HttpServletRequest request, @Valid Documento documentos, BindingResult bindingResult, Errors errors, Model modelo, RedirectAttributes redirectAttributes) throws ParseException {
if (bindingResult.hasErrors()) {
log.error("Hubo algun error en la forma, regresando");
return Constantes.DOCUMENTOCOLPORTOR_PATH_EDITA;
}
switch (documentos.getTipoDeDocumento()) {
case "0":
documentos.setTipoDeDocumento(Constantes.DEPOSITO_CAJA);
break;
case "1":
documentos.setTipoDeDocumento(Constantes.DEPOSITO_BANCO);
break;
case "2":
documentos.setTipoDeDocumento(Constantes.DIEZMO);
break;
case "3":
documentos.setTipoDeDocumento(Constantes.NOTAS_DE_COMPRA);
break;
case "4":
documentos.setTipoDeDocumento(Constantes.BOLETIN);
break;
case "5":
documentos.setTipoDeDocumento(Constantes.INFORME);
break;
}
try {
SimpleDateFormat sdf = new SimpleDateFormat(Constantes.DATE_SHORT_HUMAN_PATTERN);
documentos.setFecha(sdf.parse(request.getParameter("fecha")));
} catch (ConstraintViolationException e) {
log.error("Fecha", e);
return Constantes.DOCUMENTOCOLPORTOR_PATH_EDITA;
}
try {
TemporadaColportor temporadaColportorTmp = null;
if(ambiente.esColportor()){
temporadaColportorTmp = temporadaColportorDao.obtiene((Colportor) ambiente.obtieneUsuario());
}
else{
//Se requiere una clave de colportor
Colportor clp = colportorDao.obtiene(((TemporadaColportor)request.getSession().getAttribute(Constantes.TEMPORADACOLPORTOR)).getColportor().getClave());
Temporada tmp = temporadaDao.obtiene(((TemporadaColportor)request.getSession().getAttribute(Constantes.TEMPORADACOLPORTOR)).getTemporada().getId());
temporadaColportorTmp = temporadaColportorDao.obtiene(clp, tmp);
}
documentos.setTemporadaColportor(temporadaColportorTmp);
log.debug("Documento Fecha" + documentos.getFecha());
documentos = DocumentoDao.actualiza(documentos);
} catch (ConstraintViolationException e) {
log.error("No se pudo actualizar el documento", e);
return Constantes.DOCUMENTOCOLPORTOR_PATH_EDITA;
}
redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE, "documento.actualizado.message");
redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{documentos.getFolio()});
return "redirect:" + Constantes.DOCUMENTOCOLPORTOR_PATH_VER + "/" + documentos.getId();
}
@Transactional
@RequestMapping(value = "/elimina", method = RequestMethod.POST)
public String elimina(HttpServletRequest request, @RequestParam Long id, Model modelo, @ModelAttribute Documento documentos, BindingResult bindingResult, RedirectAttributes redirectAttributes) {
log.debug("Elimina documento");
try {
String folio = DocumentoDao.elimina(id);
redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE, "documento.eliminado.message");
redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{folio});
} catch (Exception e) {
log.error("No se pudo eliminar el documento " + id, e);
bindingResult.addError(new ObjectError(Constantes.DOCUMENTOCOLPORTOR, new String[]{"documento.no.eliminado.message"}, null, null));
return Constantes.DOCUMENTOCOLPORTOR_PATH_VER;
}
return "redirect:" + Constantes.DOCUMENTOCOLPORTOR_PATH;
}
private void generaReporte(String tipo, List<Documento> documentos, HttpServletResponse response) throws JRException, IOException {
log.debug("Generando reporte {}", tipo);
byte[] archivo = null;
switch (tipo) {
case Constantes.TIPO_DOCUMENTO_PDF:
archivo = generaPdf(documentos);
response.setContentType("application/pdf");
response.addHeader("Content-Disposition", "attachment; filename=Documentoes.pdf");
break;
case Constantes.TIPO_DOCUMENTO_CSV:
archivo = generaCsv(documentos);
response.setContentType("text/csv");
response.addHeader("Content-Disposition", "attachment; filename=Documentoes.csv");
break;
case Constantes.TIPO_DOCUMENTO_XLS:
archivo = generaXls(documentos);
response.setContentType("application/vnd.ms-excel");
response.addHeader("Content-Disposition", "attachment; filename=Documentoes.xls");
}
if (archivo != null) {
response.setContentLength(archivo.length);
try (BufferedOutputStream bos = new BufferedOutputStream(response.getOutputStream())) {
bos.write(archivo);
bos.flush();
}
}
}
private void enviaCorreo(String tipo, List<Documento> documentos, HttpServletRequest request) throws JRException, MessagingException {
log.debug("Enviando correo {}", tipo);
byte[] archivo = null;
String tipoContenido = null;
switch (tipo) {
case Constantes.TIPO_DOCUMENTO_PDF:
archivo = generaPdf(documentos);
tipoContenido = "application/pdf";
break;
case Constantes.TIPO_DOCUMENTO_CSV:
archivo = generaCsv(documentos);
tipoContenido = "text/csv";
break;
case Constantes.TIPO_DOCUMENTO_XLS:
archivo = generaXls(documentos);
tipoContenido = "application/vnd.ms-excel";
}
MimeMessage message = mailSender.createMimeMessage();
MimeMessageHelper helper = new MimeMessageHelper(message, true);
helper.setTo(ambiente.obtieneUsuario().getUsername());
String titulo = messageSource.getMessage("documento.lista.label", null, request.getLocale());
helper.setSubject(messageSource.getMessage("envia.correo.titulo.message", new String[]{titulo}, request.getLocale()));
helper.setText(messageSource.getMessage("envia.correo.contenido.message", new String[]{titulo}, request.getLocale()), true);
helper.addAttachment(titulo + "." + tipo, new ByteArrayDataSource(archivo, tipoContenido));
mailSender.send(message);
}
private byte[] generaPdf(List documentos) throws JRException {
Map<String, Object> params = new HashMap<>();
JasperDesign jd = JRXmlLoader.load(this.getClass().getResourceAsStream("/mx/edu/um/mateo/general/reportes/documentos.jrxml"));
JasperReport jasperReport = JasperCompileManager.compileReport(jd);
JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, params, new JRBeanCollectionDataSource(documentos));
byte[] archivo = JasperExportManager.exportReportToPdf(jasperPrint);
return archivo;
}
private byte[] generaCsv(List documentos) throws JRException {
Map<String, Object> params = new HashMap<>();
JRCsvExporter exporter = new JRCsvExporter();
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
JasperDesign jd = JRXmlLoader.load(this.getClass().getResourceAsStream("/mx/edu/um/mateo/general/reportes/documentos.jrxml"));
JasperReport jasperReport = JasperCompileManager.compileReport(jd);
JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, params, new JRBeanCollectionDataSource(documentos));
exporter.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
exporter.setParameter(JRExporterParameter.OUTPUT_STREAM, byteArrayOutputStream);
exporter.exportReport();
byte[] archivo = byteArrayOutputStream.toByteArray();
return archivo;
}
private byte[] generaXls(List documentos) throws JRException {
Map<String, Object> params = new HashMap<>();
JRXlsExporter exporter = new JRXlsExporter();
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
JasperDesign jd = JRXmlLoader.load(this.getClass().getResourceAsStream("/mx/edu/um/mateo/general/reportes/documentos.jrxml"));
JasperReport jasperReport = JasperCompileManager.compileReport(jd);
JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, params, new JRBeanCollectionDataSource(documentos));
exporter.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
exporter.setParameter(JRExporterParameter.OUTPUT_STREAM, byteArrayOutputStream);
exporter.setParameter(JRXlsExporterParameter.IS_WHITE_PAGE_BACKGROUND, Boolean.FALSE);
exporter.setParameter(JRXlsExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_ROWS, Boolean.TRUE);
exporter.setParameter(JRXlsExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_COLUMNS, Boolean.TRUE);
exporter.setParameter(JRXlsExporterParameter.IS_COLLAPSE_ROW_SPAN, Boolean.TRUE);
exporter.setParameter(JRXlsExporterParameter.IGNORE_PAGE_MARGINS, Boolean.TRUE);
exporter.setParameter(JRXlsExporterParameter.IS_ONE_PAGE_PER_SHEET, Boolean.FALSE);
exporter.exportReport();
byte[] archivo = byteArrayOutputStream.toByteArray();
return archivo;
}
}