All checks were successful
		
		
	
	Optimized Build and Deploy / remote-build-and-deploy (push) Successful in 7m55s
				
			
		
			
				
	
	
		
			114 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
using GestionIntegral.Api.Dtos.Reportes.ViewModels;
 | 
						|
using QuestPDF.Fluent;
 | 
						|
using QuestPDF.Helpers;
 | 
						|
using QuestPDF.Infrastructure;
 | 
						|
using System.Globalization;
 | 
						|
using System.Linq;
 | 
						|
 | 
						|
namespace GestionIntegral.Api.Controllers.Reportes.PdfTemplates
 | 
						|
{
 | 
						|
  public class ComparativaConsumoBobinasDocument : IDocument
 | 
						|
  {
 | 
						|
    public ComparativaConsumoBobinasViewModel Model { get; }
 | 
						|
 | 
						|
    public ComparativaConsumoBobinasDocument(ComparativaConsumoBobinasViewModel 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 Consumo de Bobinas - Comparativa Mensual").SemiBold().FontSize(14);
 | 
						|
 | 
						|
        string subTitle = Model.EsConsolidado ? "Consolidado" : $"Planta: {Model.NombrePlanta}";
 | 
						|
        column.Item().AlignCenter().Text(subTitle).FontSize(12);
 | 
						|
 | 
						|
        column.Item().PaddingTop(5, Unit.Millimetre).Row(row =>
 | 
						|
      {
 | 
						|
          // Le damos una proporción menor al texto de la izquierda (que es corto y fijo).
 | 
						|
            row.RelativeItem(1).Text(text =>
 | 
						|
          {
 | 
						|
                text.Span("Fecha del Reporte: ").SemiBold().FontSize(12);
 | 
						|
                text.Span(Model.FechaReporte);
 | 
						|
              });
 | 
						|
 | 
						|
          // Le damos una proporción mayor al texto de la derecha (que es largo y variable).
 | 
						|
          // El factor "2" significa que tendrá el doble de espacio disponible que el item con factor "1".
 | 
						|
            row.RelativeItem(2).AlignRight().Text(text =>
 | 
						|
          {
 | 
						|
                text.Span("Meses: ").SemiBold().FontSize(12);
 | 
						|
                text.Span($"{Model.MesA} (Mes A) contra {Model.MesB} (Mes B)").FontSize(12);
 | 
						|
              });
 | 
						|
          });
 | 
						|
      });
 | 
						|
    }
 | 
						|
 | 
						|
    void ComposeContent(IContainer container)
 | 
						|
    {
 | 
						|
      container.PaddingTop(5, Unit.Millimetre).Table(table =>
 | 
						|
      {
 | 
						|
        table.ColumnsDefinition(columns =>
 | 
						|
              {
 | 
						|
            columns.RelativeColumn(3); // Tipo Bobina
 | 
						|
            columns.RelativeColumn(1); columns.RelativeColumn(1); columns.RelativeColumn(1); // Grupo Cantidad
 | 
						|
            columns.RelativeColumn(1); columns.RelativeColumn(1); columns.RelativeColumn(1); // Grupo Kilos
 | 
						|
          });
 | 
						|
 | 
						|
        table.Header(header =>
 | 
						|
              {
 | 
						|
                // Fila 1 del Encabezado
 | 
						|
            header.Cell().RowSpan(2).Border(1).Background(Colors.Grey.Lighten3).Padding(4).AlignMiddle().Text("Tipo Bobina").SemiBold();
 | 
						|
            header.Cell().ColumnSpan(3).Border(1).Background(Colors.Grey.Lighten3).Padding(4).AlignCenter().Text("Cantidad Bobinas").SemiBold();
 | 
						|
            header.Cell().ColumnSpan(3).Border(1).Background(Colors.Grey.Lighten3).Padding(4).AlignCenter().Text("Kilos Utilizados").SemiBold();
 | 
						|
 | 
						|
                // Fila 2 del Encabezado
 | 
						|
            header.Cell().Border(1).Background(Colors.Grey.Lighten3).Padding(2).AlignRight().Text("Mes A").SemiBold();
 | 
						|
            header.Cell().Border(1).Background(Colors.Grey.Lighten3).Padding(2).AlignRight().Text("Mes B").SemiBold();
 | 
						|
            header.Cell().Border(1).Background(Colors.Grey.Lighten3).Padding(2).AlignRight().Text("Diferencia").SemiBold();
 | 
						|
            header.Cell().Border(1).Background(Colors.Grey.Lighten3).Padding(2).AlignRight().Text("Kg Mes A").SemiBold();
 | 
						|
            header.Cell().Border(1).Background(Colors.Grey.Lighten3).Padding(2).AlignRight().Text("Kg Mes B").SemiBold();
 | 
						|
            header.Cell().Border(1).Background(Colors.Grey.Lighten3).Padding(2).AlignRight().Text("Diferencia").SemiBold();
 | 
						|
          });
 | 
						|
 | 
						|
        foreach (var item in Model.Detalles.OrderBy(x => x.TipoBobina))
 | 
						|
        {
 | 
						|
          table.Cell().Border(1).Padding(3).Text(item.TipoBobina);
 | 
						|
          table.Cell().Border(1).Padding(3).AlignRight().Text(item.BobinasUtilizadasMesA.ToString("N0"));
 | 
						|
          table.Cell().Border(1).Padding(3).AlignRight().Text(item.BobinasUtilizadasMesB.ToString("N0"));
 | 
						|
          table.Cell().Border(1).Padding(3).AlignRight().Text(item.DiferenciaBobinasUtilizadas.ToString("N0"));
 | 
						|
          table.Cell().Border(1).Padding(3).AlignRight().Text(item.KilosUtilizadosMesA.ToString("N0"));
 | 
						|
          table.Cell().Border(1).Padding(3).AlignRight().Text(item.KilosUtilizadosMesB.ToString("N0"));
 | 
						|
          table.Cell().Border(1).Padding(3).AlignRight().Text(item.DiferenciaKilosUtilizados.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.BobinasUtilizadasMesA).ToString("N0")).Style(style));
 | 
						|
        table.Cell().Border(1).Padding(3).AlignRight().Text(text => text.Span(Model.Detalles.Sum(x => x.BobinasUtilizadasMesB).ToString("N0")).Style(style));
 | 
						|
        table.Cell().Border(1).Padding(3).AlignRight().Text(text => text.Span(Model.Detalles.Sum(x => x.DiferenciaBobinasUtilizadas).ToString("N0")).Style(style));
 | 
						|
        table.Cell().Border(1).Padding(3).AlignRight().Text(text => text.Span(Model.Detalles.Sum(x => x.KilosUtilizadosMesA).ToString("N0")).Style(style));
 | 
						|
        table.Cell().Border(1).Padding(3).AlignRight().Text(text => text.Span(Model.Detalles.Sum(x => x.KilosUtilizadosMesB).ToString("N0")).Style(style));
 | 
						|
        table.Cell().Border(1).Padding(3).AlignRight().Text(text => text.Span(Model.Detalles.Sum(x => x.DiferenciaKilosUtilizados).ToString("N0")).Style(style));
 | 
						|
      });
 | 
						|
    }
 | 
						|
  }
 | 
						|
} |