using FoodOrdersBusinessLogic.OfficePackage; using FoodOrdersBusinessLogic.OfficePackage.HelperModels; using FoodOrdersContracts.BindingModels; using FoodOrdersContracts.BusinessLogicsContracts; using FoodOrdersContracts.SearchModels; using FoodOrdersContracts.StoragesContracts; using FoodOrdersContracts.ViewModels; namespace FoodOrdersBusinessLogic.BusinessLogics { public class ReportLogic : IReportLogic { private readonly IDishStorage _dishStorage; private readonly IOrderStorage _orderStorage; private readonly AbstractSaveToExcel _saveToExcel; private readonly AbstractSaveToWord _saveToWord; private readonly AbstractSaveToPdf _saveToPdf; public ReportLogic(IDishStorage dishStorage, IComponentStorage componentStorage, IOrderStorage orderStorage, AbstractSaveToExcel saveToExcel, AbstractSaveToWord saveToWord, AbstractSaveToPdf saveToPdf) { _dishStorage = dishStorage; _orderStorage = orderStorage; _saveToExcel = saveToExcel; _saveToWord = saveToWord; _saveToPdf = saveToPdf; } public List GetDishComponents() { var dishs = _dishStorage.GetFullList(); var list = new List(); foreach (var dish in dishs) { var record = new ReportDishComponentViewModel { DishName = dish.DishName, Components = new List<(string Component, int Count)>(), TotalCount = 0, }; foreach (var component in dish.DishComponents) { record.Components.Add(new(component.Value.Item1.ComponentName, component.Value.Item2)); record.TotalCount += component.Value.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, DishName = x.DishName, OrderStatus = x.Status.ToString(), Sum = x.Sum }) .ToList(); } public void SaveDishsToWordFile(ReportBindingModel model) { _saveToWord.CreateDoc(new WordInfo { FileName = model.FileName, Title = "Список блюд", Dishs = _dishStorage.GetFullList() }); } public void SaveDishComponentToExcelFile(ReportBindingModel model) { _saveToExcel.CreateReport(new ExcelInfo { FileName = model.FileName, Title = "Список блюд", DishComponents = GetDishComponents() }); } public void SaveOrdersToPdfFile(ReportBindingModel model) { _saveToPdf.CreateDoc(new PdfInfo { FileName = model.FileName, Title = "Список заказов", DateFrom = model.DateFrom!.Value, DateTo = model.DateTo!.Value, Orders = GetOrders(model) }); } } }