112 lines
4.4 KiB
C#
112 lines
4.4 KiB
C#
|
|
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 ?? "-");
|
||
|
|
}
|
||
|
|
});
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|