using BankBusinessLogic.OfficePackage.HelperEnums; using BankBusinessLogic.OfficePackage.HelperModels; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace BankBusinessLogic.OfficePackage { public abstract class AbstractSaveToPdf { public MemoryStream CreateOperatorDoc(PdfInfo info) { if (info.Transfers == null) { throw new ArgumentNullException("Данные для отчёта отсутсвуют!", nameof(info.Transfers)); } CreatePdf(info); CreateParagraph(new PdfParagraph { Text = info.Title, Style = "NormalTitle", ParagraphAlignment = PdfParagraphAlignmentType.Center }); CreateParagraph(new PdfParagraph { Text = $"с {info.DateFrom.ToShortDateString()} по {info.DateTo.ToShortDateString()}", Style = "Normal", ParagraphAlignment = PdfParagraphAlignmentType.Center }); CreateTable(new List { "4cm", "3cm", "3cm", "2cm", "3cm", "3cm" }); CreateRow(new PdfRowParameters { Texts = new List { "Номер зачисления", "Дата зачисления", "Номер закупки", "Сумма", "Валюта", "Дата закупки" }, Style = "NormalTitle", ParagraphAlignment = PdfParagraphAlignmentType.Center }); foreach (var transfer in info.Transfers) { CreateRow(new PdfRowParameters { Texts = new List { "Зачисление №" + transfer.TransferId, transfer.TransferDate.ToShortDateString(), "", "", "", "" }, Style = "Normal", ParagraphAlignment = PdfParagraphAlignmentType.Left }); foreach(var purchase in transfer.Purchases) { CreateRow(new PdfRowParameters { Texts = new List { "", "", "Закупка №" + purchase.Id, purchase.Amount.ToString(), purchase.CurrencyName.ToString(), purchase.PurchaseDate.ToShortDateString()}, Style = "Normal", ParagraphAlignment = PdfParagraphAlignmentType.Left }); } } return SavePdf(); } /// /// Создание doc-файла /// /// protected abstract void CreatePdf(PdfInfo info); /// /// Создание параграфа с текстом /// /// /// protected abstract void CreateParagraph(PdfParagraph paragraph); /// /// Создание таблицы /// /// /// protected abstract void CreateTable(List columns); /// /// Создание и заполнение строки /// /// protected abstract void CreateRow(PdfRowParameters rowParameters); /// /// Сохранение файла /// /// protected abstract MemoryStream SavePdf(); } }