using FurnitureAssemblyBusinessLogic.OfficePackage; using FurnitureAssemblyBusinessLogic.OfficePackage.HelperModels; using FurnitureAssemblyContracts.BindingModels; using FurnitureAssemblyContracts.BusinessLogicContracts; using FurnitureAssemblyContracts.SearchModels; using FurnitureAssemblyContracts.StorageContracts; using FurnitureAssemblyContracts.ViewModels; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace FurnitureAssemblyBusinessLogic.BusinessLogics { public class ReportLogic : IReportLogic { private readonly IFurnitureModuleStorage _furnitureModuleStorage; private readonly ISetStorage _setStorage; private readonly IOrderStorage _orderStorage; private readonly AbstractSaveToExcel _saveToExcel; private readonly AbstractSaveToWord _saveToWord; private readonly AbstractSaveToPdf _saveToPdf; public ReportLogic(ISetStorage setStorage, IFurnitureModuleStorage furnitureModuleStorage, IOrderStorage orderStorage, AbstractSaveToExcel saveToExcel, AbstractSaveToWord saveToWord, AbstractSaveToPdf saveToPdf) { _setStorage = setStorage; _furnitureModuleStorage = furnitureModuleStorage; _orderStorage = orderStorage; _saveToExcel = saveToExcel; _saveToWord = saveToWord; _saveToPdf = saveToPdf; } /// /// Получение списка мебельных модулей с указанием, в каких гарнитурах используются /// /// public List GetSetFurnitureModule() { var furnitureModules = _furnitureModuleStorage.GetFullList(); var sets = _setStorage.GetFullList(); var list = new List(); foreach (var set in sets) { var record = new ReportSetFurnitureModuleViewModel { SetName = set.Name, FurnitureModules = new List<(string, int)>(), TotalCount = 0 }; foreach (var furnitureModule in furnitureModules) { if (set.SetFurnitureModules.ContainsKey(furnitureModule.Id)) { record.FurnitureModules.Add(new(furnitureModule.Name, set.SetFurnitureModules[furnitureModule.Id].Item2)); record.TotalCount += set.SetFurnitureModules[furnitureModule.Id].Item2; } } list.Add(record); } return list; } /// /// Получение списка заказов за определенный период /// /// /// public List GetOrders(ReportBindingModel model) { var orders = _orderStorage .GetFilteredList(new OrderSearchModel { DateFrom = model.DateFrom, DateTo = model.DateTo }); var sets = _setStorage.GetFullList(); var furnitureModules = _furnitureModuleStorage.GetFullList(); var list = new List(); foreach (var order in orders) { var record = new ReportOrdersViewModel { Id = order.Id, SetName = order.SetName, DateCreate = order.DateCreate, FurnitureModules = new List<(string, double)>(), TotalCount = 0 }; foreach (var set in sets) { if (set.Id == order.SetId) { foreach (var furnitureModule in furnitureModules) { if (set.SetFurnitureModules.ContainsKey(furnitureModule.Id)) { record.FurnitureModules.Add(new(furnitureModule.Name, furnitureModule.Cost)); record.TotalCount += set.SetFurnitureModules[furnitureModule.Id].Item2; } } } } list.Add(record); } return list; } /// /// Сохранение компонент в файл-Word /// /// public void SaveFurnitureModuleToWordFile(ReportBindingModel model) { _saveToWord.CreateDoc(new WordInfo { FileName = model.FileName, Title = "Список компонент", Sets = _setStorage.GetFullList() }); } /// /// Сохранение компонент с указаеним продуктов в файл-Excel /// /// public void SaveSetFurnitureModuleToExcelFile(ReportBindingModel model) { _saveToExcel.CreateReport(new ExcelInfo { FileName = model.FileName, Title = "Список компонент", SetFurnitureModules = GetSetFurnitureModule() }); } /// /// Сохранение заказов в файл-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) }); } } }