175 lines
6.2 KiB
C#
175 lines
6.2 KiB
C#
using ServiceStationBusinessLogic.OfficePackage;
|
|
using ServiceStationBusinessLogic.OfficePackage.HelperModels;
|
|
using ServiceStationContracts.BindingModels;
|
|
using ServiceStationContracts.BusinessLogicsContracts;
|
|
using ServiceStationContracts.SearchModels;
|
|
using ServiceStationContracts.StoragesContracts;
|
|
using ServiceStationContracts.ViewModels;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace ServiceStationBusinessLogic.BusinessLogics
|
|
{
|
|
public class ExecutorReportLogic : IExecutorReportLogic
|
|
{
|
|
|
|
private readonly ITechnicalWorkStorage _techWorkStorage;
|
|
private readonly IRepairStorage _repairStorage;
|
|
private readonly IWorkStorage _workStorage;
|
|
private readonly ICarStorage _carStorage;
|
|
private readonly AbstractSaveToExcelExecutor _saveToExcel;
|
|
private readonly AbstractSaveToWordExecutor _saveToWord;
|
|
private readonly AbstractSaveToPdfExecutor _saveToPdf;
|
|
|
|
public ExecutorReportLogic(ITechnicalWorkStorage technicalWorkStorage, IRepairStorage repairStorage, IWorkStorage workStorage, ICarStorage carStorage,
|
|
AbstractSaveToExcelExecutor saveToExcel, AbstractSaveToWordExecutor saveToWord, AbstractSaveToPdfExecutor saveToPdf)
|
|
{
|
|
_techWorkStorage = technicalWorkStorage;
|
|
_repairStorage = repairStorage;
|
|
_workStorage = workStorage;
|
|
_carStorage = carStorage;
|
|
_saveToExcel = saveToExcel;
|
|
_saveToWord = saveToWord;
|
|
_saveToPdf = saveToPdf;
|
|
}
|
|
|
|
public List<ReportWorksViewModel> GetWorks(List<int> Ids)
|
|
{
|
|
if(Ids == null) return new List<ReportWorksViewModel>();
|
|
|
|
List<ReportWorksViewModel> allList = new List<ReportWorksViewModel>();
|
|
|
|
double price = 0;
|
|
|
|
var works = _workStorage.GetFullList();
|
|
List<CarViewModel> cars = new List<CarViewModel>();
|
|
foreach (var carId in Ids)
|
|
{
|
|
var car = _carStorage.GetElement(new CarSearchModel
|
|
{
|
|
Id = carId,
|
|
});
|
|
if(car != null)
|
|
{
|
|
cars.Add(car);
|
|
}
|
|
}
|
|
|
|
foreach(var car in cars)
|
|
{
|
|
var rec = new ReportWorksViewModel
|
|
{
|
|
CarNumber = car.CarNumber,
|
|
WorksInfo = new List<(string, double)>()
|
|
};
|
|
foreach(var work in works)
|
|
{
|
|
var techWork = _techWorkStorage.GetElement(new TechnicalWorkSearchModel
|
|
{
|
|
Id = work.TechnicalWorkId,
|
|
});
|
|
foreach(var techCars in techWork.TechnicalWorkCars.Values)
|
|
{
|
|
if(techCars.Id == car.Id)
|
|
{
|
|
rec.WorksInfo.Add(new(work.WorkName, work.WorkPrice));
|
|
price += work.WorkPrice;
|
|
}
|
|
}
|
|
}
|
|
rec.FullPrice = price;
|
|
allList.Add(rec);
|
|
}
|
|
return allList;
|
|
}
|
|
public List<ReportCarsViewModel> GetCars(ReportExecutorBindingModel model)
|
|
{
|
|
List<ReportCarsViewModel> allList = new List<ReportCarsViewModel>();
|
|
|
|
List<TechnicalWorkViewModel> techWorkList = _techWorkStorage.GetFilteredList(new TechnicalWorkSearchModel
|
|
{
|
|
DateFrom = model.DateFrom,
|
|
DateTo = model.DateTo,
|
|
ExecutorId = model.ExecutorId,
|
|
});
|
|
|
|
foreach(var techWork in techWorkList)
|
|
{
|
|
foreach(var car in techWork.TechnicalWorkCars.Values)
|
|
{
|
|
allList.Add(new ReportCarsViewModel
|
|
{
|
|
CarNumber = car.CarNumber,
|
|
CarBrand = car.CarBrand,
|
|
WorkType = techWork.WorkType,
|
|
TechnicalWorkDate = techWork.DateStartWork,
|
|
TechnicalWorkPrice = techWork.WorkPrice,
|
|
});
|
|
}
|
|
}
|
|
|
|
List<RepairViewModel> repairList = _repairStorage.GetFilteredList(new RepairSearchModel
|
|
{
|
|
DateFrom = model.DateFrom,
|
|
DateTo = model.DateTo,
|
|
});
|
|
|
|
foreach(var repair in repairList)
|
|
{
|
|
allList.Add(new ReportCarsViewModel
|
|
{
|
|
RepairName = repair.RepairName,
|
|
RepairStartDate = repair.RepairStartDate,
|
|
RepairPrice = repair.RepairPrice,
|
|
});
|
|
}
|
|
|
|
return allList;
|
|
}
|
|
|
|
public void SaveWorkByCarsWordFile(ReportExecutorBindingModel model)
|
|
{
|
|
_saveToWord.CreateDoc(new WordInfoExecutor
|
|
{
|
|
FileName = model.FileName,
|
|
Title = "Список работ",
|
|
WorksByCar = GetWorks(model.Ids!)
|
|
});
|
|
}
|
|
|
|
public void SaveTechWorkAndRepairsByCarsToPdfFile(ReportExecutorBindingModel model)
|
|
{
|
|
if(model.DateFrom == null)
|
|
{
|
|
throw new ArgumentException("Дата начала не задана");
|
|
}
|
|
if(model.DateTo == null)
|
|
{
|
|
throw new ArgumentException("Дата окончания не задана");
|
|
}
|
|
|
|
_saveToPdf.CreateDoc(new PdfInfoExecutor
|
|
{
|
|
FileName = model.FileName,
|
|
Title = "Список машин",
|
|
DateFrom = model.DateFrom.Value,
|
|
DateTo = model.DateTo.Value,
|
|
Cars = GetCars(model)
|
|
});
|
|
}
|
|
|
|
public void SaveWorkByCarsToExcelFile(ReportExecutorBindingModel model)
|
|
{
|
|
_saveToExcel.CreateReport(new ExcelInfoExecutor
|
|
{
|
|
FileName = model.FileName,
|
|
Title = "Список работ",
|
|
WorksByCar = GetWorks(model.Ids!)
|
|
});
|
|
}
|
|
}
|
|
}
|