using BankYouBankruptBusinessLogic.OfficePackage; using BankYouBankruptBusinessLogic.OfficePackage.HelperModels; using BankYouBankruptContracts.BindingModels; using BankYouBankruptContracts.BusinessLogicsContracts; using BankYouBankruptContracts.SearchModels; using BankYouBankruptContracts.StoragesContracts; using BankYouBankruptContracts.ViewModels; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace BankYouBankruptBusinessLogic.BusinessLogics { public class ReportCashierLogic : IReportCashierLogic { private readonly IMoneyTransferStorage _moneyTransferStorage; private readonly ICashWithdrawalStorage _cashWithdrawalStorage; //private readonly IAccountStorage _accountStorage; private readonly AbstractSaveToExcelCashier _saveToExcel; private readonly AbstractSaveToWordCashier _saveToWord; private readonly AbstractSaveToPdfCashier _saveToPdf; //инициализируем поля класса через контейнер public ReportCashierLogic(IMoneyTransferStorage moneyTransferStorage, ICashWithdrawalStorage cashWithdrawalStorage, IAccountStorage accountStorage, AbstractSaveToExcelCashier saveToExcel, AbstractSaveToWordCashier saveToWord, AbstractSaveToPdfCashier saveToPdf) { _moneyTransferStorage = moneyTransferStorage; _cashWithdrawalStorage = cashWithdrawalStorage; //_accountStorage = accountStorage; _saveToExcel = saveToExcel; _saveToWord = saveToWord; _saveToPdf = saveToPdf; } public List? GetMoneyTransfers(ReportBindingModel model) { return _moneyTransferStorage.GetFilteredList(new MoneyTransferSearchModel { DateOperation = model.DateOperation}) .Select(x => new ReportCashierViewModel { AccountId = x.Id, DateComplite = x.DateComplite, ClientName = x.ClientName, SumOperation = x.SumOperation, TypeOperation = x.TypeOperation }) .ToList(); } public List? GetCashWithrawals(ReportBindingModel model) { return _accountStorage.GetFilteredList(new CashWithdrawalSearchModel { DateFrom = model.DateFrom, DateTo = model.DateTo }) .Select(x => new ReportOrdersViewModel { Id = x.Id, DateCreate = x.DateCreate, ManufactureName = x.ManufactureName, Sum = x.Sum, OrderStatus = x.Status.ToString() }) .ToList(); } //Сохранение мороженных в файл-Word public void SaveAccountsToWordFile(ReportBindingModel model) { _saveToWord.CreateDoc(new WordInfo { FileName = model.FileName, Title = "Список изделий", Accounts = _accountStorage.GetFullList() }); } //Сохранение заготовок с указаеним изделий в файл-Excel public void SaveAccountsToExcelFile(ReportBindingModel model) { _saveToExcel.CreateReport(new ExcelInfo { FileName = model.FileName, Title = "Список заготовок", Accounts = _accountStorage.GetFullList() }); } //Сохранение заказов в файл-Pdf public void SaveAccountsToPdfFile(ReportBindingModel model) { _saveToPdf.CreateDoc(new PdfInfo { FileName = model.FileName, Title = "Список заказов", DateFrom = model.DateFrom!.Value, DateTo = model.DateTo!.Value, ReportAccounts = GetAccounts(model) }); } } }