Beispiel #1
0
        public CertificadoPTModelo GetCertificadoPT(string codigo)
        {
            CertificadoPTModelo certificadopt = new CertificadoPTModelo();

            try
            {
                ConsultaMySql consulta = new ConsultaMySql(@"SELECT * from sacc_certificado_analisis c
                                                            LEFT JOIN sacc_analistas a ON c.codigo_analista = a.codigo
                                                            LEFT JOIN users u ON a.username = u.username 
                                                             where c.codigo_certificado = '" + codigo + @"';");
                DataTable     dt       = consulta.EjecutarConsulta(Parametros.ConexionBDMySQL());
                if (dt.Rows.Count <= 0)
                {
                    throw new Exception("No trajo datos de la consulta de la base de datos:");
                }

                foreach (DataRow item in dt.Rows)
                {
                    CertificadoPTModelo cpt = new CertificadoPTModelo
                    {
                        id_certificado_analisis = Convert.ToInt32(item["id_certificado_analisis"]),
                        codigo_certificado      = item["codigo_certificado"].ToString(),
                        codigo_analista         = (item["codigo_analista"]).ToString(),
                        protocolo                   = (item["protocolo"]).ToString(),
                        fecha_analisis              = Convert.ToDateTime(item["fecha_analisis"]),
                        lote                        = (item["lote"]).ToString(),
                        fecha_fabricacion           = Convert.ToDateTime(item["fecha_fabricacion"]),
                        fecha_vencimiento           = Convert.ToDateTime(item["fecha_vencimiento"]),
                        cantidad_fabricada          = (item["cantidad_fabricada"]).ToString(),
                        cantidad_liberada           = (item["cantidad_liberada"]).ToString(),
                        tipo_certificado            = (item["tipo_certificado"]).ToString(),
                        tipo_clasificacion_producto = (item["tipo_clasificacion_producto"]).ToString(),
                        codigo_producto             = (item["codigo_producto"]).ToString(),
                        dictamen                    = (item["dictamen"]).ToString(),
                        presentacion                = (item["presentacion"]).ToString(),
                        conservacionyalm            = (item["conservacionyalm"]).ToString(),
                        referencias                 = (item["referencias"]).ToString(),
                        observaciones               = (item["observaciones"]).ToString(),
                        tipo_impresion              = (item["tipo_impresion"]).ToString(),
                        nombre_producto             = (item["nombre_producto"]).ToString(),
                        concentracion               = (item["concentracion"]).ToString(),
                        forma_farmaceutica          = (item["forma_farmaceutica"]).ToString(),
                        nombre_proveedor            = (item["nombre_proveedor"]).ToString(),
                        usuario_creacion            = (item["usuario_creacion"]).ToString(),
                        fecha_creacion              = Convert.ToDateTime(item["fecha_creacion"]),
                        usuario_modificacion        = (item["usuario_modificacion"]).ToString(),
                        fecha_modificacion          = Convert.ToDateTime(item["fecha_modificacion"])
                    };
                    certificadopt = cpt;
                }
                return(certificadopt);
            }
            catch (Exception ex)
            {
                return(certificadopt);
            }
        }
Beispiel #2
0
        public void Crear(CertificadoPTModelo certificado, List <CaracteristicaCertificadoModelo> lcf, List <CaracteristicaCertificadoModelo> laq, List <CaracteristicaCertificadoModelo> lcm)
        {
            string appRootDir = Parametros.rutaCertificadoPT();// string appRootDir = HttpContext.Current.Server.MapPath("~/certificadospt/"); //new DirectoryInfo(Environment.SystemDirectory).Parent.FullName;

            try
            {
                // Step 1: Creating System.IO.FileStream object
                using (FileStream fs = new FileStream(appRootDir + certificado.codigo_certificado.Replace("/", "#") + ".pdf", FileMode.Create, FileAccess.Write, FileShare.None))
                    // Step 2: Creating iTextSharp.text.Document object
                    using (Document doc = new Document(PageSize.LEGAL, 25f, 25f, 90f, 0f))
                        // Step 3: Creating iTextSharp.text.pdf.PdfWriter object
                        // It helps to write the Document to the Specified FileStream
                        using (PdfWriter writer = PdfWriter.GetInstance(doc, fs))
                        {
                            writer.PageEvent = new HeaderFooter(certificado.tipo_clasificacion_producto);
                            // Step 4: Openning the Document
                            doc.Open();

                            #region CABECERA DEL REPORTE DE PRODUCTO TERMINADO

                            PdfPTable tblfor = new PdfPTable(5);
                            tblfor.SpacingBefore = 0f;
                            tblfor.SpacingAfter  = 4f;
                            float[] widths_tf = new float[] { 1.25f, 1.25f, 2f, 1.25f, 1.25f };
                            tblfor.SetWidths(widths_tf);
                            tblfor.WidthPercentage = 100f;

                            PdfPCell cvaciofor = new PdfPCell(new Paragraph(""));
                            cvaciofor.Colspan             = 4;
                            cvaciofor.Border              = 0;
                            cvaciofor.HorizontalAlignment = Element.ALIGN_CENTER;
                            tblfor.AddCell(cvaciofor);
                            PdfPCell cfor = new PdfPCell(new Paragraph("FOR813302", this.font11));
                            cfor.Border = 0;
                            cfor.HorizontalAlignment = Element.ALIGN_CENTER;
                            tblfor.AddCell(cfor);
                            doc.Add(tblfor);

                            PdfPTable tprotocolo = new PdfPTable(5);
                            tprotocolo.SpacingBefore = 0f;
                            tprotocolo.SpacingAfter  = 2f;
                            float[] widths_tp = new float[] { 1.25F, 1.25F, 2f, 1.25f, 1.25f };
                            tprotocolo.SetWidths(widths_tp);
                            tprotocolo.WidthPercentage = 100f;

                            PdfPCell cvacio = new PdfPCell(new Paragraph("", this.font10b));
                            cvacio.Colspan             = 3;
                            cvacio.Border              = 0;
                            cvacio.HorizontalAlignment = Element.ALIGN_RIGHT;
                            tprotocolo.AddCell(cvacio);
                            PdfPCell cprotocolo = new PdfPCell(new Paragraph("PROTOCOLO:", this.font10b));
                            cprotocolo.Border = 0;
                            cprotocolo.HorizontalAlignment = Element.ALIGN_CENTER;
                            tprotocolo.AddCell(cprotocolo);
                            PdfPCell cnprotocolo = new PdfPCell(new Paragraph(certificado.protocolo, this.font10));
                            cnprotocolo.HorizontalAlignment = Element.ALIGN_CENTER;
                            tprotocolo.AddCell(cnprotocolo);
                            doc.Add(tprotocolo);

                            PdfPTable tcabecera = new PdfPTable(5);
                            tcabecera.SpacingBefore = 0f;
                            tcabecera.SpacingAfter  = 2f;
                            float[] widths_tc = new float[] { 1.25F, 1.25F, 2f, 1.25f, 1.25f };
                            tcabecera.SetWidths(widths_tc);
                            tcabecera.WidthPercentage = 100f;
                            //tcabecera.TotalWidth = doc.PageSize.Width - doc.LeftMargin - doc.RightMargin;

                            PdfPCell cnomproducto = new PdfPCell(new Paragraph("NOMBRE PRODUCTO", this.font10b));
                            cnomproducto.Colspan             = 2;
                            cnomproducto.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(cnomproducto);
                            PdfPCell cconcentracion = new PdfPCell(new Paragraph("CONCENTRACIÓN", this.font10b));
                            cconcentracion.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(cconcentracion);
                            PdfPCell cffarmaceutica = new PdfPCell(new Paragraph("FORMA FAMACÉUTICA", this.font10b));
                            cffarmaceutica.Colspan             = 2;
                            cffarmaceutica.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(cffarmaceutica);

                            PdfPCell nproducto = new PdfPCell(new Paragraph(certificado.nombre_producto, this.font10));
                            nproducto.Colspan             = 2;
                            nproducto.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(nproducto);
                            PdfPCell concentracion = new PdfPCell(new Paragraph(certificado.concentracion, this.font10));
                            concentracion.Rowspan             = 3;
                            concentracion.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(concentracion);
                            PdfPCell ffarmaceutica = new PdfPCell(new Paragraph(certificado.forma_farmaceutica, this.font10));
                            ffarmaceutica.Colspan             = 2;
                            ffarmaceutica.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(ffarmaceutica);

                            //PdfPCell cfecanalisis = new PdfPCell(new Paragraph("FECHA DE ANÁLISIS", this.font10b));
                            // cfecanalisis.HorizontalAlignment = Element.ALIGN_CENTER;
                            // tcabecera.AddCell(cfecanalisis);

                            PdfPCell ccantidadfabricada = new PdfPCell(new Paragraph("CANTIDAD FAB.", this.font10b));
                            ccantidadfabricada.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(ccantidadfabricada);
                            PdfPCell ccnumerolote = new PdfPCell(new Paragraph("Nro. DE LOTE", this.font10b));
                            ccnumerolote.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(ccnumerolote);

                            PdfPCell fcantidadfabricada = new PdfPCell(new Paragraph("FECHA DE FAB.", this.font10b));
                            fcantidadfabricada.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(fcantidadfabricada);
                            PdfPCell fcnumerolote = new PdfPCell(new Paragraph("FECHA DE VTO.", this.font10b));
                            fcnumerolote.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(fcnumerolote);

                            PdfPCell cfecfabricacion = new PdfPCell(new Paragraph(certificado.cantidad_fabricada, this.font10));
                            cfecfabricacion.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(cfecfabricacion);
                            PdfPCell cfecvencimiento = new PdfPCell(new Paragraph(certificado.lote, this.font10));
                            cfecvencimiento.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(cfecvencimiento);


                            //PdfPCell fecanalisis = new PdfPCell(new Paragraph("2018-08-28", this.font10));
                            //fecanalisis.HorizontalAlignment = Element.ALIGN_CENTER;
                            //tcabecera.AddCell(fecanalisi

                            PdfPCell fecfabricacion = new PdfPCell(new Paragraph(certificado.fecha_fabricacion.ToShortDateString(), this.font10));
                            fecfabricacion.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(fecfabricacion);
                            PdfPCell fecvencimiento = new PdfPCell(new Paragraph(certificado.fecha_vencimiento.ToShortDateString(), this.font10));
                            fecvencimiento.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcabecera.AddCell(fecvencimiento);

                            doc.Add(tcabecera);
                            #endregion

                            #region CUERPO DETALLE DEL CERTIFICADO DE PRODUCTO TERMINADO

                            // Paragraph saltoDeLinea1 = new Paragraph("                                                                             ");
                            // doc.Add(saltoDeLinea1);

                            PdfPTable tcuerpo = new PdfPTable(3);
                            tcuerpo.SpacingBefore = 3f;
                            tcuerpo.SpacingAfter  = 2f;
                            //float[] widths_tcp = new float[] { 1.25F, 1.25F, 2f, 1.25f, 1.25f };
                            //tcuerpo.SetWidths(widths_tcp);
                            tcuerpo.WidthPercentage = 100f;
                            //tcabecera.TotalWidth = doc.PageSize.Width - doc.LeftMargin - doc.RightMargin;
                            PdfPCell censayo = new PdfPCell(new Paragraph("ENSAYO", this.font10bn));
                            censayo.BorderColor         = new iTextSharp.text.BaseColor(104, 104, 104);
                            censayo.BorderColor         = BaseColor.BLACK;
                            censayo.BorderColor         = iTextSharp.text.pdf.ExtendedColor.BLACK;
                            censayo.BackgroundColor     = new iTextSharp.text.BaseColor(104, 104, 104);
                            censayo.BackgroundColor     = BaseColor.LIGHT_GRAY;
                            censayo.BackgroundColor     = iTextSharp.text.pdf.ExtendedColor.LIGHT_GRAY;
                            censayo.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcuerpo.AddCell(censayo);
                            PdfPCell cespecificaciones = new PdfPCell(new Paragraph("ESPECIFICACIONES", this.font10bn));
                            cespecificaciones.BorderColor         = new iTextSharp.text.BaseColor(104, 104, 104);
                            cespecificaciones.BorderColor         = BaseColor.BLACK;
                            cespecificaciones.BorderColor         = iTextSharp.text.pdf.ExtendedColor.BLACK;
                            cespecificaciones.BackgroundColor     = new iTextSharp.text.BaseColor(104, 104, 104);
                            cespecificaciones.BackgroundColor     = BaseColor.LIGHT_GRAY;
                            cespecificaciones.BackgroundColor     = iTextSharp.text.pdf.ExtendedColor.LIGHT_GRAY;
                            cespecificaciones.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcuerpo.AddCell(cespecificaciones);
                            PdfPCell cresultado = new PdfPCell(new Paragraph("RESULTADO", this.font10bn));
                            cresultado.BorderColor         = new iTextSharp.text.BaseColor(104, 104, 104);
                            cresultado.BorderColor         = BaseColor.BLACK;
                            cresultado.BorderColor         = iTextSharp.text.pdf.ExtendedColor.BLACK;
                            cresultado.BackgroundColor     = new iTextSharp.text.BaseColor(104, 104, 104);
                            cresultado.BackgroundColor     = BaseColor.LIGHT_GRAY;
                            cresultado.BackgroundColor     = iTextSharp.text.pdf.ExtendedColor.LIGHT_GRAY;
                            cresultado.HorizontalAlignment = Element.ALIGN_CENTER;
                            tcuerpo.AddCell(cresultado);
                            PdfPCell ccfisicas = new PdfPCell(new Paragraph("CARACTERÍSTICAS FÍSICAS", this.font10bn));
                            ccfisicas.Colspan             = 3;
                            ccfisicas.BorderColor         = new iTextSharp.text.BaseColor(104, 104, 104);
                            ccfisicas.BorderColor         = BaseColor.BLACK;
                            ccfisicas.BorderColor         = iTextSharp.text.pdf.ExtendedColor.BLACK;
                            ccfisicas.BackgroundColor     = new iTextSharp.text.BaseColor(104, 104, 104);
                            ccfisicas.BackgroundColor     = BaseColor.LIGHT_GRAY;
                            ccfisicas.BackgroundColor     = iTextSharp.text.pdf.ExtendedColor.LIGHT_GRAY;
                            ccfisicas.HorizontalAlignment = Element.ALIGN_LEFT;
                            tcuerpo.AddCell(ccfisicas);
                            doc.Add(tcuerpo);

                            PdfPTable tbldatosfis = new PdfPTable(3);
                            tbldatosfis.SpacingAfter    = 0f;
                            tbldatosfis.SpacingAfter    = 2f;
                            tbldatosfis.WidthPercentage = 100;

                            foreach (var item in lcf)
                            {
                                PdfPCell celdatosfis = new PdfPCell(new Paragraph(item.id_caracteristica, this.font10b));
                                celdatosfis.HorizontalAlignment = Element.ALIGN_LEFT;
                                tbldatosfis.AddCell(celdatosfis);

                                PdfPCell celdatosfisa1 = new PdfPCell(new Paragraph(item.especificacion, this.font10));
                                celdatosfisa1.HorizontalAlignment = Element.ALIGN_CENTER;
                                tbldatosfis.AddCell(celdatosfisa1);

                                PdfPCell celdatosfisa2 = new PdfPCell(new Paragraph(item.resultado, this.font10));
                                celdatosfisa2.HorizontalAlignment = Element.ALIGN_CENTER;
                                tbldatosfis.AddCell(celdatosfisa2);
                            }

                            doc.Add(tbldatosfis);

                            PdfPTable tblaquimico = new PdfPTable(3);
                            tblaquimico.SpacingAfter                = 0f;
                            tblaquimico.SpacingBefore               = 2f;
                            tblaquimico.WidthPercentage             = 100;
                            tblaquimico.DefaultCell.BackgroundColor = BaseColor.RED;
                            PdfPCell caquim = new PdfPCell(new Paragraph("ANÁLISIS QUÍMICO", this.font10bn));
                            caquim.Colspan             = 3;
                            caquim.BorderColor         = new iTextSharp.text.BaseColor(104, 104, 104);
                            caquim.BorderColor         = BaseColor.BLACK;
                            caquim.BorderColor         = iTextSharp.text.pdf.ExtendedColor.BLACK;
                            caquim.BackgroundColor     = new iTextSharp.text.BaseColor(104, 104, 104);
                            caquim.BackgroundColor     = BaseColor.LIGHT_GRAY;
                            caquim.HorizontalAlignment = Element.ALIGN_LEFT;
                            tblaquimico.AddCell(caquim);
                            doc.Add(tblaquimico);

                            PdfPTable tbldatosquim = new PdfPTable(3);
                            tbldatosquim.SpacingAfter    = 0f;
                            tbldatosquim.SpacingBefore   = 2f;
                            tbldatosquim.WidthPercentage = 100;

                            foreach (var item in laq)
                            {
                                PdfPCell celdatosquim = new PdfPCell(new Paragraph(item.id_caracteristica, this.font10b));
                                celdatosquim.HorizontalAlignment = Element.ALIGN_LEFT;
                                tbldatosquim.AddCell(celdatosquim);
                                PdfPCell celdatosqa1 = new PdfPCell(new Paragraph(item.especificacion, this.font10));
                                celdatosqa1.HorizontalAlignment = Element.ALIGN_CENTER;
                                tbldatosquim.AddCell(celdatosqa1);
                                PdfPCell celdatosqa2 = new PdfPCell(new Paragraph(item.resultado, this.font10));
                                celdatosqa2.HorizontalAlignment = Element.ALIGN_CENTER;
                                tbldatosquim.AddCell(celdatosqa2);
                            }
                            doc.Add(tbldatosquim);

                            PdfPTable tblcmicrobio = new PdfPTable(3);
                            tblcmicrobio.SpacingAfter                = 0f;
                            tblcmicrobio.SpacingBefore               = 2f;
                            tblcmicrobio.WidthPercentage             = 100;
                            tblcmicrobio.DefaultCell.BackgroundColor = BaseColor.BLACK;
                            PdfPCell cconmicro = new PdfPCell(new Paragraph("CONTROL MICROBIOLÓGICO", this.font10bn));
                            cconmicro.Colspan             = 3;
                            cconmicro.BorderColor         = new iTextSharp.text.BaseColor(104, 104, 104);
                            cconmicro.BorderColor         = BaseColor.BLACK;
                            cconmicro.BorderColor         = iTextSharp.text.pdf.ExtendedColor.BLACK;
                            cconmicro.BackgroundColor     = new iTextSharp.text.BaseColor(104, 104, 104);
                            cconmicro.BackgroundColor     = BaseColor.LIGHT_GRAY;
                            cconmicro.HorizontalAlignment = Element.ALIGN_LEFT;
                            tblcmicrobio.AddCell(cconmicro);
                            doc.Add(tblcmicrobio);

                            PdfPTable tbldatosmbio = new PdfPTable(3);
                            tbldatosmbio.SpacingAfter    = 0f;
                            tbldatosmbio.SpacingBefore   = 2f;
                            tbldatosmbio.WidthPercentage = 100;
                            foreach (var item in lcm)
                            {
                                PdfPCell celdatosmbio = new PdfPCell(new Paragraph(item.id_caracteristica, this.font10b));
                                celdatosmbio.HorizontalAlignment = Element.ALIGN_LEFT;
                                tbldatosmbio.AddCell(celdatosmbio);
                                PdfPCell celdatosmca1 = new PdfPCell(new Paragraph(item.especificacion, this.font10));
                                celdatosmca1.HorizontalAlignment = Element.ALIGN_CENTER;
                                tbldatosmbio.AddCell(celdatosmca1);
                                PdfPCell celdatosmca2 = new PdfPCell(new Paragraph(item.resultado, this.font10));
                                celdatosmca2.HorizontalAlignment = Element.ALIGN_CENTER;
                                tbldatosmbio.AddCell(celdatosmca2);
                            }
                            doc.Add(tbldatosmbio);

                            Paragraph saltoDeLinea2 = new Paragraph(" ");
                            doc.Add(saltoDeLinea2);

                            PdfPTable tblpresentacion = new PdfPTable(3);
                            tblpresentacion.SpacingAfter    = 0f;
                            tblpresentacion.SpacingBefore   = 2f;
                            tblpresentacion.WidthPercentage = 100;
                            PdfPCell celdapres = new PdfPCell(new Paragraph("PRESENTACIÓN", this.font10b));
                            celdapres.HorizontalAlignment = Element.ALIGN_LEFT;
                            celdapres.Colspan             = 3;
                            tblpresentacion.AddCell(celdapres);
                            PdfPCell celdapresna = new PdfPCell(new Paragraph(certificado.presentacion, this.font10));
                            celdapresna.HorizontalAlignment = Element.ALIGN_LEFT;
                            celdapresna.Colspan             = 3;
                            celdapresna.Padding             = 10;
                            //celdapresna.Rowspan = 2;
                            tblpresentacion.AddCell(celdapresna);
                            doc.Add(tblpresentacion);

                            PdfPTable tblconservacion = new PdfPTable(3);
                            tblconservacion.SpacingAfter    = 2f;
                            tblconservacion.SpacingBefore   = 2f;
                            tblconservacion.WidthPercentage = 100;
                            PdfPCell celdacon = new PdfPCell(new Paragraph("CONSERVACIÓN Y ALMACENAMIENTO", this.font10b));
                            celdacon.HorizontalAlignment = Element.ALIGN_LEFT;
                            celdacon.Colspan             = 3;
                            tblconservacion.AddCell(celdacon);
                            PdfPCell celdacona = new PdfPCell(new Paragraph(certificado.conservacionyalm, this.font10));
                            celdacona.HorizontalAlignment = Element.ALIGN_LEFT;
                            celdacona.Colspan             = 3;
                            celdacona.Padding             = 10;
                            tblconservacion.AddCell(celdacona);
                            doc.Add(tblconservacion);

                            PdfPTable tblreferencias = new PdfPTable(3);
                            tblreferencias.SpacingBefore   = 2f;
                            tblreferencias.SpacingAfter    = 2f;
                            tblreferencias.WidthPercentage = 100;
                            PdfPCell celdaref = new PdfPCell(new Paragraph("REFERENCIAS", this.font10b));
                            celdaref.HorizontalAlignment = Element.ALIGN_LEFT;
                            celdaref.Colspan             = 3;
                            tblreferencias.AddCell(celdaref);
                            PdfPCell celdarefna = new PdfPCell(new Paragraph(certificado.referencias, this.font10));
                            celdarefna.HorizontalAlignment = Element.ALIGN_LEFT;
                            celdarefna.Colspan             = 3;
                            celdarefna.Padding             = 10;
                            tblreferencias.AddCell(celdarefna);
                            doc.Add(tblreferencias);

                            PdfPTable tblobservaciones = new PdfPTable(3);
                            //tblobservaciones.SpacingAfter = 60f;
                            tblobservaciones.SpacingAfter    = 20f;
                            tblobservaciones.SpacingBefore   = 2f;
                            tblobservaciones.WidthPercentage = 100;
                            PdfPCell celdaobs = new PdfPCell(new Paragraph("OBSERVACIONES", this.font10b));
                            celdaobs.HorizontalAlignment = Element.ALIGN_LEFT;
                            celdaobs.Colspan             = 3;
                            tblobservaciones.AddCell(celdaobs);
                            PdfPCell celdaobsna = new PdfPCell(new Paragraph(certificado.observaciones, this.font10));
                            celdaobsna.HorizontalAlignment = Element.ALIGN_LEFT;
                            celdaobsna.Colspan             = 3;
                            celdaobsna.Padding             = 10;
                            tblobservaciones.AddCell(celdaobsna);

                            doc.Add(tblobservaciones);
                            #endregion

                            #region DICTAMEN PIE DE FIRMA
                            PdfContentByte cb = writer.DirectContent;

                            PdfPTable tbldictamen = new PdfPTable(3);

                            tbldictamen.WidthPercentage = 100;

                            PdfPCell cdictamen = new PdfPCell(new Paragraph("DICTAMEN", font10b));
                            cdictamen.HorizontalAlignment = Element.ALIGN_CENTER;
                            PdfPCell canalista = new PdfPCell(new Paragraph("ANALISTA", font10b));
                            canalista.HorizontalAlignment = Element.ALIGN_CENTER;
                            PdfPCell cjefe = new PdfPCell(new Paragraph("JEFE CONTROL CALIDAD", font10b));
                            cjefe.HorizontalAlignment = Element.ALIGN_CENTER;

                            tbldictamen.AddCell(cdictamen);
                            tbldictamen.AddCell(canalista);
                            tbldictamen.AddCell(cjefe);

                            Image aprobado  = Image.GetInstance(HttpContext.Current.Server.MapPath("~/Images/aprobado.png"));
                            Image rechazado = Image.GetInstance(HttpContext.Current.Server.MapPath("~/Images/rechazado.png"));

                            float percentage = 0.0f;
                            percentage = 100 / rechazado.Width;
                            rechazado.ScalePercent(percentage * 120);
                            aprobado.ScalePercent(percentage * 120);

                            PdfPCell c11;
                            if (certificado.dictamen == "APROBADO")
                            {
                                c11 = new PdfPCell(aprobado);
                            }
                            else
                            {
                                c11 = new PdfPCell(rechazado);
                            }
                            c11.HorizontalAlignment = Element.ALIGN_CENTER;
                            c11.VerticalAlignment   = Element.ALIGN_MIDDLE;
                            c11.Rowspan             = 4;

                            PdfPCell c12 = new PdfPCell(new Paragraph(certificado.codigo_analista + "\r\n" + "FECHA: " + certificado.fecha_analisis.ToShortDateString(), font10b));
                            c12.VerticalAlignment   = Element.ALIGN_BOTTOM;
                            c12.HorizontalAlignment = Element.ALIGN_CENTER;
                            c12.Rowspan             = 4;

                            PdfPCell c13 = new PdfPCell(new Paragraph(" "));
                            c13.MinimumHeight = 40f;
                            PdfPCell c23 = new PdfPCell(new Paragraph("VoBo DIRECTOR TÉCNICO", font10b));
                            c23.HorizontalAlignment = Element.ALIGN_CENTER;
                            tbldictamen.AddCell(c11);
                            tbldictamen.AddCell(c12);
                            tbldictamen.AddCell(c13);
                            tbldictamen.AddCell(c23);

                            //PdfPCell c31 = new PdfPCell(new Paragraph("DICTAMEN"));
                            //PdfPCell c32 = new PdfPCell(new Paragraph("ANALISTA"));
                            PdfPCell c33 = new PdfPCell(new Paragraph(" "));
                            c33.MinimumHeight = 40f;
                            c33.Rowspan       = 2;
                            tbldictamen.AddCell(c33);

                            /* PdfPCell c41 = new PdfPCell(new Paragraph("FECHA: " + certificado.fecha_analisis.ToShortDateString(), font10b));
                             * c41.Colspan = 3;
                             * c41.HorizontalAlignment = Element.ALIGN_CENTER;
                             * c41.Border = 0;
                             * tbldictamen.AddCell(c41);*/

                            doc.Add(tbldictamen);
                            #endregion

                            doc.Close();
                        }
            }

            // Catching iTextSharp.text.DocumentException if any
            catch (DocumentException de)
            {
                throw de;
            }
            // Catching System.IO.IOException if any
            catch (IOException ioe)
            {
                throw ioe;
            }
        }
Beispiel #3
0
        // GET api/certificadopt/5
        public HttpResponseMessage Get(string id)

        {
            string codigo_certificado = id.Replace("|", "/"); // Obtenemos el codigo del certificado | a /

            List <CertificadoPTModelo> listacopt = new List <CertificadoPTModelo>();
            //Creamos caracteristicas certificado
            List <CaracteristicaCertificadoModelo> lcaracteristicas = new List <CaracteristicaCertificadoModelo>();

            lcaracteristicas = ccnegocio.GetDatosCaracteristicas(codigo_certificado);

            //Creamos Listas por tipo de característica
            List <CaracteristicaCertificadoModelo> lcf = new List <CaracteristicaCertificadoModelo>();
            List <CaracteristicaCertificadoModelo> laq = new List <CaracteristicaCertificadoModelo>();
            List <CaracteristicaCertificadoModelo> lcm = new List <CaracteristicaCertificadoModelo>();

            foreach (var item in lcaracteristicas)
            {
                // Console.WriteLine(item);
                CaracteristicaCertificadoModelo caracteristica = new CaracteristicaCertificadoModelo();
                caracteristica.codigo_producto     = item.codigo_producto;
                caracteristica.id_caracteristica   = item.id_caracteristica;
                caracteristica.especificacion      = item.especificacion;
                caracteristica.resultado           = item.resultado;
                caracteristica.tipo_caracteristica = item.tipo_caracteristica;
                caracteristica.estado               = item.estado;
                caracteristica.usuario_creacion     = item.usuario_creacion;
                caracteristica.fecha_creacion       = item.fecha_creacion;
                caracteristica.usuario_modificacion = item.usuario_modificacion;
                caracteristica.fecha_modificacion   = item.fecha_modificacion;

                if (caracteristica.tipo_caracteristica == "CF")
                {
                    lcf.Add(caracteristica);
                }
                else if (caracteristica.tipo_caracteristica == "AQ")
                {
                    laq.Add(caracteristica);
                }
                else
                {
                    lcm.Add(caracteristica);
                }
            }

            //Esto sirve para listar varios certificados
            //List<CertificadoMPModelo> listacmp = new List<CertificadoMPModelo>(); // Creamos la Lista de Certificados
            //listacmp = this.certificadompn.GetDatosCertificadoMP(codigo_certificado);
            List <CertificadoPTModelo> listacpt = new List <CertificadoPTModelo>();

            listacpt = this.certificadoptn.GetDatosCertificadoPT(codigo_certificado);

            CertificadoPTModelo certificado = new CertificadoPTModelo();

            certificado = certificadoptn.GetCertificadoPTReport(codigo_certificado);
            rep.Crear(certificado, lcf, laq, lcm);


            HttpResponseMessage response = new HttpResponseMessage();
            var localFilePath            = Parametros.rutaCertificadoPT() + codigo_certificado.Replace("/", "#") + ".pdf";

            byte[] pdfbytes = System.IO.File.ReadAllBytes(localFilePath);
            if (!File.Exists(localFilePath))
            {
                response = Request.CreateResponse(HttpStatusCode.Gone);
            }
            else
            {
                response.StatusCode = HttpStatusCode.OK;
                response.Content    = new ByteArrayContent(pdfbytes);
                response.Content.Headers.ContentType        = new System.Net.Http.Headers.MediaTypeHeaderValue("application/pdf");
                response.Content.Headers.ContentDisposition = new System.Net.Http.Headers.ContentDispositionHeaderValue("attachment");
            }
            return(response);
        }