using ConfectioneryBusinessLogic.OfficePackage.HelperModels; using ConfectioneryBusinessLogic.OfficePackage; using ConfectioneryContracts.BindingModels; using ConfectioneryContracts.BusinessLogicsContracts; using ConfectioneryContracts.SearchModels; using ConfectioneryContracts.StoragesContract; using ConfectioneryContracts.ViewModels; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace ConfectioneryBusinessLogic { public class ReportLogic : IReportLogic { private readonly IComponentStorage _componentStorage; private readonly IPastryStorage _pastryStorage; private readonly IOrderStorage _orderStorage; private readonly AbstractSaveToExcel _saveToExcel; private readonly AbstractSaveToWord _saveToWord; private readonly AbstractSaveToPdf _saveToPdf; public ReportLogic(IPastryStorage PastryStorage, IComponentStorage componentStorage, IOrderStorage orderStorage, AbstractSaveToExcel saveToExcel, AbstractSaveToWord saveToWord, AbstractSaveToPdf saveToPdf) { _pastryStorage = PastryStorage; _componentStorage = componentStorage; _orderStorage = orderStorage; _saveToExcel = saveToExcel; _saveToWord = saveToWord; _saveToPdf = saveToPdf; } /// /// Получение списка компонент с указанием, в каких изделиях используются /// /// public List GetPastryComponent() { var components = _componentStorage.GetFullList(); var pastries = _pastryStorage.GetFullList(); var list = new List(); foreach (var pastry in pastries) { var record = new ReportPastryComponentViewModel { PastryName = pastry.PastryName, Components = new List>(), TotalCount = 0 }; foreach (var component in components) { if (pastry.PastryComponents.ContainsKey(component.Id)) { record.Components.Add(new(component.ComponentName, pastry.PastryComponents[component.Id].Item2)); record.TotalCount += pastry.PastryComponents[component.Id].Item2; } } list.Add(record); } return list; } /// /// Получение списка заказов за определенный период /// /// /// public List GetOrders(ReportBindingModel model) { return _orderStorage.GetFilteredList(new OrderSearchModel { DateFrom = model.DateFrom, DateTo = model.DateTo }) .Select(x => new ReportOrdersViewModel { Id = x.Id, DateCreate = x.DateCreate, PastryName = x.PastryName, OrderStatus = Convert.ToString(x.Status) ?? string.Empty, Sum = x.Sum }) .ToList(); } /// /// Сохранение изделий в файл-Word /// /// public void SavePastriesToWordFile(ReportBindingModel model) { _saveToWord.CreateDoc(new WordInfo { FileName = model.FileName, Title = "Список изделий", Pastries = _pastryStorage.GetFullList() }); } /// /// Сохранение изделий с указаеним продуктов в файл-Excel /// /// public void SavePastryComponentToExcelFile(ReportBindingModel model) { _saveToExcel.CreateReport(new ExcelInfo { FileName = model.FileName, Title = "Список изделий", PastryComponents = GetPastryComponent() }); } /// /// Сохранение заказов в файл-Pdf /// /// public void SaveOrdersToPdfFile(ReportBindingModel model) { _saveToPdf.CreateDoc(new PdfInfo { FileName = model.FileName, Title = "Список заказов", DateFrom = model.DateFrom!.Value, DateTo = model.DateTo!.Value, Orders = GetOrders(model) }); } } }