All checks were successful
		
		
	
	Optimized Build and Deploy / remote-build-and-deploy (push) Successful in 7m55s
				
			
		
			
				
	
	
		
			99 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using GestionIntegral.Api.Dtos.Reportes.ViewModels;
 | |
| using QuestPDF.Fluent;
 | |
| using QuestPDF.Helpers;
 | |
| using QuestPDF.Infrastructure;
 | |
| using System.Linq;
 | |
| 
 | |
| namespace GestionIntegral.Api.Controllers.Reportes.PdfTemplates
 | |
| {
 | |
|     public class TiradasPublicacionesSeccionesDocument : IDocument
 | |
|     {
 | |
|         public TiradasPublicacionesSeccionesViewModel Model { get; }
 | |
| 
 | |
|         public TiradasPublicacionesSeccionesDocument(TiradasPublicacionesSeccionesViewModel model)
 | |
|         {
 | |
|             Model = model;
 | |
|         }
 | |
| 
 | |
|         public DocumentMetadata GetMetadata() => DocumentMetadata.Default;
 | |
| 
 | |
|         public void Compose(IDocumentContainer container)
 | |
|         {
 | |
|             container.Page(page =>
 | |
|             {
 | |
|                 page.Margin(1, Unit.Centimetre);
 | |
|                 page.DefaultTextStyle(x => x.FontFamily("Arial").FontSize(9));
 | |
|                 
 | |
|                 page.Header().Element(ComposeHeader);
 | |
|                 page.Content().Element(ComposeContent);
 | |
|                 page.Footer().AlignCenter().Text(x => { x.Span("Página "); x.CurrentPageNumber(); });
 | |
|             });
 | |
|         }
 | |
| 
 | |
|         void ComposeHeader(IContainer container)
 | |
|         {
 | |
|             container.Column(column =>
 | |
|             {
 | |
|                 column.Spacing(5);
 | |
|                 column.Item().AlignCenter().Text("Reporte de Tiradas por Publicación Mensual").SemiBold().FontSize(14);
 | |
| 
 | |
|                 // Título secundario dinámico
 | |
|                 string subTitle = Model.EsConsolidado 
 | |
|                     ? $"Consolidado - Publicación: {Model.NombrePublicacion}"
 | |
|                     : $"Planta: {Model.NombrePlanta} - Publicación: {Model.NombrePublicacion}";
 | |
|                 column.Item().AlignCenter().Text(subTitle).FontSize(12);
 | |
|                 
 | |
|                 column.Item().PaddingTop(5, Unit.Millimetre).Row(row =>
 | |
|                 {
 | |
|                     row.RelativeItem().Text(text => { text.Span("Fecha del Reporte: ").SemiBold(); text.Span(Model.FechaReporte); });
 | |
|                     row.RelativeItem().AlignRight().Text(text => { text.Span("Mes Consultado: ").SemiBold(); text.Span(Model.MesConsultado); });
 | |
|                 });
 | |
|             });
 | |
|         }
 | |
|         
 | |
|         void ComposeContent(IContainer container)
 | |
|         {
 | |
|             container.PaddingTop(5, Unit.Millimetre).Table(table =>
 | |
|             {
 | |
|                 table.ColumnsDefinition(columns =>
 | |
|                 {
 | |
|                     columns.RelativeColumn(2.5f); // Nombre Seccion
 | |
|                     columns.RelativeColumn(1.5f); // Páginas Impresas
 | |
|                     columns.RelativeColumn(1);    // Total Ediciones
 | |
|                     columns.RelativeColumn(1.5f); // Pág. Por Edición
 | |
|                     columns.RelativeColumn(1.2f); // Total Ejemplares
 | |
|                     columns.RelativeColumn(1.5f); // Pág. Ejemplar
 | |
|                 });
 | |
| 
 | |
|                 table.Header(header =>
 | |
|                 {
 | |
|                     header.Cell().Border(1).Background(Colors.Grey.Lighten3).Padding(4).Text("Nombre Sección");
 | |
|                     header.Cell().Border(1).Background(Colors.Grey.Lighten3).Padding(4).AlignRight().Text("Páginas Impresas");
 | |
|                     header.Cell().Border(1).Background(Colors.Grey.Lighten3).Padding(4).AlignRight().Text("Total Ediciones");
 | |
|                     header.Cell().Border(1).Background(Colors.Grey.Lighten3).Padding(4).AlignRight().Text("Prom. Pág/Edición");
 | |
|                     header.Cell().Border(1).Background(Colors.Grey.Lighten3).Padding(4).AlignRight().Text("Total Ejemplares");
 | |
|                     header.Cell().Border(1).Background(Colors.Grey.Lighten3).Padding(4).AlignRight().Text("Prom. Pág/Ejemplar");
 | |
|                 });
 | |
| 
 | |
|                 foreach (var item in Model.Detalles.OrderBy(x => x.NombreSeccion))
 | |
|                 {
 | |
|                     table.Cell().Border(1).Padding(3).Text(item.NombreSeccion);
 | |
|                     table.Cell().Border(1).Padding(3).AlignRight().Text(item.TotalPaginasImpresas.ToString("N0"));
 | |
|                     table.Cell().Border(1).Padding(3).AlignRight().Text(item.CantidadTiradas.ToString("N0"));
 | |
|                     table.Cell().Border(1).Padding(3).AlignRight().Text(item.TotalPaginasEjemplares.ToString("N0"));
 | |
|                     table.Cell().Border(1).Padding(3).AlignRight().Text(item.TotalEjemplares.ToString("N0"));
 | |
|                     table.Cell().Border(1).Padding(3).AlignRight().Text(item.PromedioPaginasPorEjemplar.ToString("N0"));
 | |
|                 }
 | |
|                 
 | |
|                 // Fila de Totales
 | |
|                 var style = TextStyle.Default.SemiBold();
 | |
|                 table.Cell().Border(1).Padding(3).AlignRight().Text(text => text.Span("Totales").Style(style));
 | |
|                 table.Cell().Border(1).Padding(3).AlignRight().Text(text => text.Span(Model.Detalles.Sum(x => x.TotalPaginasImpresas).ToString("N0")).Style(style));
 | |
|                 table.Cell().Border(1).Padding(3).AlignRight().Text(text => text.Span(Model.Detalles.Sum(x => x.CantidadTiradas).ToString("N0")).Style(style));
 | |
|                 table.Cell().Border(1).Padding(3).AlignRight().Text(text => text.Span(Model.Detalles.Sum(x => x.TotalPaginasEjemplares).ToString("N0")).Style(style));
 | |
|                 table.Cell().Border(1).Padding(3).AlignRight().Text(text => text.Span(Model.Detalles.Sum(x => x.TotalEjemplares).ToString("N0")).Style(style));
 | |
|                 table.Cell().Border(1).Padding(3).AlignRight().Text(text => text.Span(Model.Detalles.Sum(x => x.PromedioPaginasPorEjemplar).ToString("N0")).Style(style));
 | |
|             });
 | |
|         }
 | |
|     }
 | |
| } |