Java tutorial
/* * To change this license header, choose License Headers in Project Properties. * To change this template file, choose Tools | Templates * and open the template in the editor. */ package Controller; import Model.DTO.ObjCompra; import Model.DTO.ObjDetalleMovimiento; import Model.DTO.ObjUsuario; import Model.Data.ModelCompra; import com.google.gson.Gson; import com.itextpdf.text.*; import com.itextpdf.text.pdf.*; import java.io.IOException; import java.io.OutputStream; import java.sql.ResultSet; import java.text.NumberFormat; import java.util.ArrayList; import java.util.LinkedHashMap; import java.util.List; import java.util.Locale; import java.util.Map; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import net.sf.jasperreports.engine.*; import javax.servlet.ServletException; import net.sf.jasperreports.engine.design.JasperDesign; import net.sf.jasperreports.engine.xml.JRXmlLoader; /** * * @author siete */ public class ControllerCompra extends HttpServlet { ModelCompra daoModelCompra; ObjCompra _objCompra = new ObjCompra(); ObjUsuario _objUsuario = new ObjUsuario(); List<ObjDetalleMovimiento> listObjDetalleMovimientos = new ArrayList<>(); ObjDetalleMovimiento _objDetalleMovimiento = new ObjDetalleMovimiento(); /** * Processes requests for both HTTP <code>GET</code> and <code>POST</code> * methods. * * @param request servlet request * @param response servlet response * @throws ServletException if a servlet-specific error occurs * @throws IOException if an I/O error occurs */ protected void processRequest(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=UTF-8"); if (request.getParameter("action") != null) { //int estado = 0; String url = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + request.getContextPath(); String action = request.getParameter("action"); switch (action) { case "Registrar": { String documentoUsuario = (request.getParameter("documentoUsuario")); String facturaProveedor = (request.getParameter("txtNumeroFactura")); String nombreProveedor = (request.getParameter("txtNombre")); int lenght = Integer.parseInt(request.getParameter("size")); int totalCompra = Integer.parseInt(request.getParameter("txtTotalCompra")); listObjDetalleMovimientos = new ArrayList<>(); for (int i = 0; i < lenght; i++) { _objDetalleMovimiento = new ObjDetalleMovimiento(); _objDetalleMovimiento .setIdArticulo(Integer.parseInt(request.getParameter("lista[" + i + "][idArticulo]"))); _objDetalleMovimiento .setCantidad(Integer.parseInt(request.getParameter("lista[" + i + "][cantidad]"))); _objDetalleMovimiento.setPrecioArticulo( Integer.parseInt(request.getParameter("lista[" + i + "][precioArticulo]"))); _objDetalleMovimiento.setTotalDetalleMovimiento( _objDetalleMovimiento.getCantidad() * _objDetalleMovimiento.getPrecioArticulo()); _objDetalleMovimiento.setDescuento(lenght); listObjDetalleMovimientos.add(_objDetalleMovimiento); } _objUsuario.setDocumentoUsuario(documentoUsuario); _objCompra.setFacturaProveedor(facturaProveedor); _objCompra.setNombreProveedor(nombreProveedor); _objCompra.setTotalCompra(totalCompra); daoModelCompra = new ModelCompra(); String salida = Mensaje(daoModelCompra.Add(_objCompra, _objUsuario, listObjDetalleMovimientos), "La compra ha sido registrada", "Ha ocurrido un error"); daoModelCompra.Signout(); response.setContentType("application/json"); response.setCharacterEncoding("UTF-8"); response.getWriter().write(salida); break; } case "Consultar": { int id = Integer.parseInt(request.getParameter("id")); response.setContentType("application/json"); response.setCharacterEncoding("UTF-8"); response.getWriter().write(consultarDetalle(id)); break; } case "Enlistar": { response.setContentType("application/json"); response.setCharacterEncoding("UTF-8"); response.getWriter().write(getTableCompra()); break; } //<editor-fold defaultstate="collapsed" desc="PDF mediante iText"> case "Imprimir": { response.setContentType("application/pdf"); try { Locale loc = Locale.getDefault(); NumberFormat currencyFormatter = NumberFormat.getCurrencyInstance(loc); //Primero obtengo el id del Movimiento int id = Integer.parseInt(request.getParameter("id")); //Obtengo el reporte a manera de Map Map material = reporte(id); //Topo ese reporte y lo divido, primero en la compra y luego el detalle Map<String, String> compra = (Map) material.get("Compra"); List<Map> detalle = (List) material.get("Detalle"); //Creo el documento y obtengo el canal de comunicacion con el servidor, para luego enviar el documento. Document document = new Document(); OutputStream os = response.getOutputStream(); //Creo una instancia a partir del documento y del canal PdfWriter.getInstance(document, os); //Abro el documento document.open(); Image logo = Image.getInstance(url + "/public/images/logo.png"); logo.scaleAbsolute(new Rectangle(logo.getPlainWidth() / 4, logo.getPlainHeight() / 4)); document.add(logo); //Creo una fuente para la letra en negrilla final Font helveticaBold = new Font(Font.FontFamily.HELVETICA, 12, Font.BOLD); //Escribo y agrego un primer parrafo con los datos basicos de la compra Paragraph headerDerecha = new Paragraph(); headerDerecha.add(new Chunk("Nombre del Proveedor: ", helveticaBold)); headerDerecha.add(new Chunk(compra.get("nombreProveedor") + "\n")); headerDerecha.add(new Chunk("Factura del Proveedor: ", helveticaBold)); headerDerecha.add(new Chunk(compra.get("facturaProveedor") + "\n")); headerDerecha.add(new Chunk("Fecha Compra: ", helveticaBold)); headerDerecha.add(new Chunk(compra.get("fechaCompra") + "\n")); //Escribo y agrego un segundo parrafo con los datos basicos de Stelarte Paragraph headerIzquierda = new Paragraph(); headerIzquierda.add(new Chunk("Stelarte.Decoracion \n", helveticaBold)); headerIzquierda.add(new Chunk("Direccin: ", helveticaBold)); headerIzquierda.add(new Chunk("Calle Falsa 123 # 12a34\n")); headerIzquierda.add(new Chunk("Telfono: ", helveticaBold)); headerIzquierda.add(new Chunk("2583697 \n")); //Agrego los dos anteriores parrafos al Header PdfPTable header = new PdfPTable(2); header.getDefaultCell().setBorder(0); header.addCell(headerIzquierda); header.addCell(headerDerecha); header.setWidthPercentage(100f); header.setSpacingAfter(20); document.add(header); //Creo la tabla del detalle PdfPTable tablaDetalle = new PdfPTable(new float[] { 1, 3, 2, 2 }); tablaDetalle.getDefaultCell().setHorizontalAlignment(Element.ALIGN_CENTER); //Creo el titulo, le quito el borde, le digo que ocupara cuatro columnas y que ser centrado PdfPCell tituloCell = new PdfPCell(new Phrase("Detalle de Compra", helveticaBold)); tituloCell.setBorder(0); tituloCell.setColspan(4); tituloCell.setHorizontalAlignment(Element.ALIGN_CENTER); tablaDetalle.addCell(tituloCell); //Aqui creo cada cabecera tablaDetalle.getDefaultCell().setBackgroundColor(BaseColor.LIGHT_GRAY); tablaDetalle.addCell(new Phrase("ID", helveticaBold)); tablaDetalle.addCell(new Phrase("Nombre", helveticaBold)); tablaDetalle.addCell(new Phrase("Cantidad", helveticaBold)); tablaDetalle.addCell(new Phrase("Valor", helveticaBold)); tablaDetalle.getDefaultCell().setBackgroundColor(null); //Aqui agrego la tabla cada articulo. for (Map<String, String> next : detalle) { tablaDetalle.addCell(next.get("idArticulo")); tablaDetalle.addCell(next.get("descripcionArticulo")); tablaDetalle.addCell(next.get("cantidad")); tablaDetalle .addCell(currencyFormatter.format(Integer.parseInt(next.get("precioArticulo")))); } //Creo el Footer headerIzquierda = new Paragraph(); headerIzquierda.add(new Chunk("Total: ", helveticaBold)); headerIzquierda .add(new Chunk(currencyFormatter.format(Integer.parseInt(compra.get("totalCompra"))))); PdfPCell footerCell = new PdfPCell(headerIzquierda); footerCell.setBorder(0); footerCell.setColspan(4); footerCell.setHorizontalAlignment(Element.ALIGN_RIGHT); tablaDetalle.addCell(footerCell); //Establesco el tamao y posicion de la tabla, luego la agrego al documento tablaDetalle.setWidthPercentage(100f); tablaDetalle.setHorizontalAlignment(Element.ALIGN_RIGHT); document.add(tablaDetalle); //Cierro el documento y lo envio con flush. document.close(); response.setHeader("Content-Disposition", "attachment;filename=\"reporte.pdf\""); os.flush(); os.close(); } catch (DocumentException de) { throw new IOException(de.getMessage()); } break; } //</editor-fold> //<editor-fold defaultstate="collapsed" desc="PDF mediante iReports"> case "Imprimir2": { try { int id = Integer.parseInt(request.getParameter("id")); String source = url + "/reports/newReport1.jrxml"; JasperPrint jasperPrint = null; JasperReport jasperReport = null; JasperDesign jasperDesign = null; System.out.println(source); String reportPath = request.getServletContext().getRealPath("reports") + "\\newReport1.jrxml"; jasperDesign = JRXmlLoader.load(reportPath); jasperReport = JasperCompileManager.compileReport(jasperDesign); jasperPrint = JasperFillManager.fillReport(jasperReport, reporte(id), daoModelCompra.getConnection()); JasperExportManager.exportReportToPdfStream(jasperPrint, response.getOutputStream()); } catch (Exception ex) { for (StackTraceElement ruta : ex.getStackTrace()) { System.err.println(ruta); } } } break; //</editor-fold> } } } public String getTableCompra() { ResultSet result; List<String[]> lista = new ArrayList<>(); try { daoModelCompra = new ModelCompra(); result = daoModelCompra.ListAll(); while (result.next()) { String[] arreglo = new String[5]; arreglo[0] = result.getString("facturaProveedor").trim(); arreglo[1] = result.getString("nombreProveedor").trim(); arreglo[2] = result.getString("fechaCompra").trim(); arreglo[3] = result.getString("totalCompra").trim(); arreglo[4] = "<a class=\"btn-sm btn-success btn-block\" href=\"javascript:void(0)\" onclick=\"compra.consultar(" + result.getString("idMovimiento") + ")\">" + "<span class=\"glyphicon glyphicon-search\"></span></a>"; lista.add(arreglo); } } catch (Exception e) { System.err.println("Ha Ocurrido un error en el controller compra " + e.toString()); } finally { daoModelCompra.Signout(); } String salida = new Gson().toJson(lista); salida = "{\"data\":" + salida + "}"; return salida; } public String Mensaje(boolean entrada, String mensajeSuccess, String mensajeError) { Map<String, String> mensaje = new LinkedHashMap<>(); if (entrada) { mensaje.put("mensaje", mensajeSuccess); mensaje.put("tipo", "success"); } else { mensaje.put("mensaje", mensajeError); mensaje.put("tipo", "error"); } String salida = new Gson().toJson(mensaje); return salida; } // <editor-fold defaultstate="collapsed" desc="HttpServlet methods. Click on the + sign on the left to edit the code."> /** * Handles the HTTP <code>GET</code> method. * * @param request servlet request * @param response servlet response * @throws ServletException if a servlet-specific error occurs * @throws IOException if an I/O error occurs */ @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { processRequest(request, response); } /** * Handles the HTTP <code>POST</code> method. * * @param request servlet request * @param response servlet response * @throws ServletException if a servlet-specific error occurs * @throws IOException if an I/O error occurs */ @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { processRequest(request, response); } /** * Returns a short description of the servlet. * * @return a String containing servlet description */ @Override public String getServletInfo() { return "Short description"; }// </editor-fold> private String consultarDetalle(int id) { Map<String, Object> lista = new LinkedHashMap<>(); List<Map> lista2 = new ArrayList<>(); Map<String, String> resultado = null; daoModelCompra = new ModelCompra(); try { ResultSet[] result = daoModelCompra.ConsultarCompra(id); while (result[0].next()) { resultado = new LinkedHashMap<>(); resultado.put("idMovimiento", result[0].getString("idMovimiento")); resultado.put("fechaCompra", result[0].getString("fechaCompra")); resultado.put("totalCompra", result[0].getString("totalCompra")); resultado.put("documentoUsuario", result[0].getString("documentoUsuario")); resultado.put("facturaProveedor", result[0].getString("facturaProveedor")); resultado.put("nombreProveedor", result[0].getString("nombreProveedor")); lista.put("Compra", resultado); } while (result[1].next()) { resultado = new LinkedHashMap<>(); resultado.put("idDetalleMovimiento", result[1].getString("idDetalleMovimiento")); resultado.put("idArticulo", result[1].getString("idArticulo")); resultado.put("descripcionArticulo", result[1].getString("descripcionArticulo")); resultado.put("cantidad", result[1].getString("cantidad")); resultado.put("descuento", result[1].getString("descuento")); resultado.put("totalDetalleMovimiento", result[1].getString("totalDetalleMovimiento")); resultado.put("idMovimiento", result[1].getString("idMovimiento")); resultado.put("precioArticulo", result[1].getString("precioArticulo")); lista2.add(resultado); } //listas.put("Compra",lista); lista.put("Detalle", lista2); } catch (Exception e) { } daoModelCompra.Signout(); String salida = new Gson().toJson(lista); return salida; } private Map reporte(int id) { Map<String, Object> lista = new LinkedHashMap<>(); List<Map> lista2 = new ArrayList<>(); Map<String, String> resultado = null; daoModelCompra = new ModelCompra(); try { ResultSet[] result = daoModelCompra.ConsultarCompra(id); while (result[0].next()) { resultado = new LinkedHashMap<>(); resultado.put("idMovimiento", result[0].getString("idMovimiento")); resultado.put("fechaCompra", result[0].getString("fechaCompra")); resultado.put("totalCompra", result[0].getString("totalCompra")); resultado.put("documentoUsuario", result[0].getString("documentoUsuario")); resultado.put("facturaProveedor", result[0].getString("facturaProveedor")); resultado.put("nombreProveedor", result[0].getString("nombreProveedor")); lista.put("Compra", resultado); } while (result[1].next()) { resultado = new LinkedHashMap<>(); resultado.put("idDetalleMovimiento", result[1].getString("idDetalleMovimiento")); resultado.put("idArticulo", result[1].getString("idArticulo")); resultado.put("descripcionArticulo", result[1].getString("descripcionArticulo")); resultado.put("cantidad", result[1].getString("cantidad")); resultado.put("descuento", result[1].getString("descuento")); resultado.put("totalDetalleMovimiento", result[1].getString("totalDetalleMovimiento")); resultado.put("idMovimiento", result[1].getString("idMovimiento")); resultado.put("precioArticulo", result[1].getString("precioArticulo")); lista2.add(resultado); } //listas.put("Compra",lista); lista.put("Detalle", lista2); } catch (Exception e) { } daoModelCompra.Signout(); return lista; } }