CourseWorkElectronicsShop/ElectronicsShop/ElectronicsShopBusinessLogic/BusinessLogic/ReportEmployeeLogic.cs
2024-08-03 22:10:14 +04:00

121 lines
5.3 KiB
C#

using DocumentFormat.OpenXml.Office.CustomUI;
using ElectronicsShopBusinessLogic.OfficePackage;
using ElectronicsShopBusinessLogic.OfficePackage.HelperModels;
using ElectronicsShopContracts.BindingModels;
using ElectronicsShopContracts.BusinessLogicContracts;
using ElectronicsShopContracts.SearchModels;
using ElectronicsShopContracts.StorageContracts;
using ElectronicsShopContracts.ViewModels;
using PdfSharp.Pdf;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace ElectronicsShopBusinessLogic.BusinessLogic
{
public class ReportEmployeeLogic : IReportEmployeeLogic
{
private readonly IProductStorage _productStorage;
private readonly IPaymeantStorage _paymeantStorage;
private readonly IOrderStorage _orderStorage;
private readonly AbstractSaveToPdfEmployee _saveToPdf;
private readonly AbstractSaveToWordEmployee _saveToWord;
private readonly AbstractSaveToExcelEmployee _saveToExcel;
public ReportEmployeeLogic(AbstractSaveToExcelEmployee abstractSaveToExcelEmployee, AbstractSaveToWordEmployee abstractSaveToWordEmployee,
AbstractSaveToPdfEmployee abstractSaveToPdfEmployee ,IProductStorage productStorage,
IPaymeantStorage paymeantStorage, IOrderStorage orderStorage) {
_productStorage = productStorage;
_paymeantStorage = paymeantStorage;
_orderStorage = orderStorage;
_saveToExcel = abstractSaveToExcelEmployee;
_saveToWord = abstractSaveToWordEmployee;
_saveToPdf = abstractSaveToPdfEmployee;
}
public List<ReportProductInPaymeantsViewModel> GetProducts(ReportProductBindingModel model)
{
var paymeants = _paymeantStorage.GetFillteredList(new PaymeantSearchModel {
DateFrom = model.DateFrom,
DateTo = model.DateTo,
});
List<PaymeantProduct> paymeantProductList = new();
foreach (var paymeant in paymeants) {
var order = _orderStorage.GetElement(new OrderSearchModel { ID = paymeant.OrderID }) ?? throw new Exception("Ошибка получения данных");
foreach (var product in order.ProductList) {
paymeantProductList.Add(new(paymeant.ID, product.Key, product.Value.Item2));
}
}
paymeantProductList.OrderBy(x => x.ProductID);
List<ReportProductInPaymeantsViewModel> ansProductsList = new();
List<string> productNames = new();
foreach (var pp in paymeantProductList) {
var product = _productStorage.GetElement(new ProductSearchModel { ID = pp.ProductID})
?? throw new Exception("Ошибка получения данных");
if (productNames.Contains(product.ProductName) == false) {
productNames.Add(product.ProductName);
// создаем запись
var record = new ReportProductInPaymeantsViewModel {
ProductName = product.ProductName,
Values = new(),
Total = 0
};
ansProductsList.Add(record);
}
// Ищем запись и вносим изменения
int index = ansProductsList.IndexOf(ansProductsList.First(x => x.ProductName == product.ProductName));
var paymeant = _paymeantStorage.GetElement(new PaymeantSearchModel { ID = pp.PaymeantID })
?? throw new Exception("Ошибка получения данных");
ansProductsList[index].Values.Add(new(pp.PaymeantID, pp.Count, paymeant.PayOption.ToString(), product.Price * pp.Count));
ansProductsList[index].Total++;
}
return ansProductsList;
}
public byte[]? SaveProductsToExcelFile(ReportProductBindingModel model)
{
var document = _saveToExcel.CreateReport(new ExcelInfoEmployee
{
Title = "Список оплат электротоваров",
ListProduct = GetProducts(model),
DateTo = model.DateTo,
DateFrom = model.DateFrom
});
return document;
}
public PdfDocument SaveProductsToPdfFile(ReportProductBindingModel model) {
var document = _saveToPdf.CreateDoc(new PdfInfoEmployee {
Title = "Список оплат электротоваров",
DateFrom = model.DateFrom,
DateTo = model.DateTo,
ListProduct = GetProducts(model),
FileName = "Report"
});
return document;
}
public byte[]? SaveProductsToWordFile(ReportProductBindingModel model)
{
var document = _saveToWord.CreateDoc(new WordInfoEmployee {
Title = "Список оплат электротоваров",
ListProduct = GetProducts(model),
DateFrom = model.DateFrom,
DateTo = model.DateTo,
});
return document;
}
}
}