108 lines
3.4 KiB
C#
108 lines
3.4 KiB
C#
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<ReportCashierViewModel>? 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<ReportCashierViewModel>? 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)
|
||
});
|
||
}
|
||
}
|
||
}
|