using GestionIntegral.Api.Dtos.Reportes.ViewModels; using QuestPDF.Fluent; using QuestPDF.Helpers; using QuestPDF.Infrastructure; namespace GestionIntegral.Api.Controllers.Reportes.PdfTemplates { public class DistribucionSuscripcionesDocument : IDocument { public DistribucionSuscripcionesViewModel Model { get; } public DistribucionSuscripcionesDocument(DistribucionSuscripcionesViewModel 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.Item().Row(row => { row.RelativeItem().Column(col => { col.Item().Text("Reporte de Distribución de Suscripciones").SemiBold().FontSize(14); col.Item().Text($"Período: {Model.FechaDesde} al {Model.FechaHasta}").FontSize(11); }); row.ConstantItem(150).AlignRight().Text($"Generado: {Model.FechaGeneracion}"); }); column.Item().PaddingTop(5).BorderBottom(1).BorderColor(Colors.Grey.Lighten2); }); } void ComposeContent(IContainer container) { container.PaddingTop(10).Column(column => { column.Spacing(20); foreach (var empresa in Model.DatosAgrupados) { column.Item().Element(c => ComposeEmpresa(c, empresa)); } }); } void ComposeEmpresa(IContainer container, GrupoEmpresa empresa) { container.Column(column => { column.Item().Background(Colors.Grey.Lighten2).Padding(5).Text(empresa.NombreEmpresa).Bold().FontSize(12); column.Item().Column(colPub => { colPub.Spacing(10); foreach (var publicacion in empresa.Publicaciones) { colPub.Item().Element(c => ComposePublicacion(c, publicacion)); } }); }); } void ComposePublicacion(IContainer container, GrupoPublicacion publicacion) { container.Table(table => { table.ColumnsDefinition(columns => { columns.RelativeColumn(2.5f); // Nombre columns.RelativeColumn(3); // Dirección columns.RelativeColumn(1.5f); // Teléfono columns.RelativeColumn(1.5f); // Días columns.RelativeColumn(2.5f); // Observaciones }); table.Header(header => { header.Cell().ColumnSpan(5).Background(Colors.Grey.Lighten4).Padding(3) .Text(publicacion.NombrePublicacion).SemiBold().FontSize(10); header.Cell().BorderBottom(1).Padding(2).Text("Suscriptor").SemiBold(); header.Cell().BorderBottom(1).Padding(2).Text("Dirección").SemiBold(); header.Cell().BorderBottom(1).Padding(2).Text("Teléfono").SemiBold(); header.Cell().BorderBottom(1).Padding(2).Text("Días Entrega").SemiBold(); header.Cell().BorderBottom(1).Padding(2).Text("Observaciones").SemiBold(); }); foreach (var item in publicacion.Suscripciones) { table.Cell().Padding(2).Text(item.NombreSuscriptor); table.Cell().Padding(2).Text(item.Direccion); table.Cell().Padding(2).Text(item.Telefono ?? "-"); table.Cell().Padding(2).Text(item.DiasEntrega); table.Cell().Padding(2).Text(item.Observaciones ?? "-"); } }); } } }