using SushiBarBusinessLogic.OfficePackage.HelperModels; using SushiBarBusinessLogic.OfficePackage; using SushiBarContracts.BindingModels; using SushiBarContracts.BusinessLogicsContracts; using SushiBarContracts.SearchModels; using SushiBarContracts.StoragesContracts; using SushiBarContracts.ViewModels; namespace SushiBarBusinessLogic.BusinessLogics { public class ReportLogic : IReportLogic { private readonly ISushiStorage _sushiStorage; private readonly IOrderStorage _orderStorage; private readonly IShopStorage _shopStorage; private readonly AbstractSaveToExcel _saveToExcel; private readonly AbstractSaveToWord _saveToWord; private readonly AbstractSaveToPdf _saveToPdf; public ReportLogic(ISushiStorage productStorage, IOrderStorage orderStorage, AbstractSaveToExcel saveToExcel, AbstractSaveToWord saveToWord, AbstractSaveToPdf saveToPdf, IShopStorage shopStorage) { _sushiStorage = productStorage; _orderStorage = orderStorage; _shopStorage = shopStorage; _saveToExcel = saveToExcel; _saveToWord = saveToWord; _saveToPdf = saveToPdf; } /// /// Получение списка ингредиентов с указанием, в каких суши используются /// /// public List GetSushiIngredient() { var listSushi = _sushiStorage.GetFullList(); var list = new List(); foreach (var sushi in listSushi) { var record = new ReportSushiIngredientViewModel { SushiName = sushi.SushiName, Ingredients = new(), TotalCount = 0 }; foreach (var ingredient in sushi.SushiIngredients) { record.Ingredients.Add(new(ingredient.Value.Item1.IngredientName, ingredient.Value.Item2)); record.TotalCount += ingredient.Value.Item2; } list.Add(record); } return list; } /// /// Получение списка суши с указанием, в каких магазинах используются /// /// public List GetShopSushi() { var shops = _shopStorage.GetFullList(); var list = new List(); foreach (var shop in shops) { var record = new ReportShopSushiViewModel { ShopName = shop.ShopName, ListSushi = new(), TotalCount = 0 }; foreach (var sushi in shop.ListSushi) { record.ListSushi.Add(new(sushi.Value.Item1.SushiName, sushi.Value.Item2)); record.TotalCount += sushi.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, SushiName = x.SushiName, OrderStatus = x.Status.ToString(), Sum = x.Sum }) .ToList(); } /// /// Получение списка заказов, сгруппированных по дате /// /// /// public List GetOrdersGroupedByDate() { return _orderStorage.GetFullList() .GroupBy(x => x.DateCreate.Date) .Select(x => new ReportOrdersGroupedByDateViewModel { DateCreate = x.Key, Count = x.Count(), Sum = x.Sum(x => x.Sum) }) .ToList(); } /// /// Сохранение суши в файл-Word /// /// public void SaveListSushiToWordFile(ReportBindingModel model) { _saveToWord.CreateDoc(new WordInfo { FileName = model.FileName, Title = "Список суши", ListSushi = _sushiStorage.GetFullList() }); } /// /// Сохранение магазинов в файл-Word /// /// public void SaveShopsToWordFile(ReportBindingModel model) { _saveToWord.CreateShopsDoc(new WordInfo { FileName = model.FileName, Title = "Список магазинов", Shops = _shopStorage.GetFullList() }); } /// /// Сохранение ингредиентов с указаеним суши в файл-Excel /// /// public void SaveSushiIngredientToExcelFile(ReportBindingModel model) { _saveToExcel.CreateReport(new ExcelInfo { FileName = model.FileName, Title = "Список суши", SushiIngredients = GetSushiIngredient() }); } /// /// Сохранение ингредиентов с указаеним суши в файл-Excel /// /// public void SaveShopSushiToExcelFile(ReportBindingModel model) { _saveToExcel.CreateShopReport(new ExcelInfo { FileName = model.FileName, Title = "Список магазинов", ShopListSushi = GetShopSushi() }); } /// /// Сохранение заказов в файл-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) }); } /// /// Сохранение заказов в файл-Pdf /// /// public void SaveOrdersGroupedByDateToPdfFile(ReportBindingModel model) { _saveToPdf.CreateOrdersGroupedByDateDoc(new PdfInfo { FileName = model.FileName, Title = "Список заказов", OrdersGroupedByDate = GetOrdersGroupedByDate() }); } } }