/* * 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; } }