2022-04-29 15:39:12 +05:00
|
|
|
|
using AsbCloudApp.Data;
|
2022-06-29 13:04:30 +05:00
|
|
|
|
using AsbCloudInfrastructure.Services.DailyReport.DailyReportBlocks;
|
2022-04-29 15:39:12 +05:00
|
|
|
|
using ClosedXML.Excel;
|
|
|
|
|
using System.IO;
|
|
|
|
|
namespace AsbCloudInfrastructure.Services.DailyReport
|
|
|
|
|
{
|
|
|
|
|
public class DailyReportMakerExcel
|
|
|
|
|
{
|
2022-06-30 16:01:46 +05:00
|
|
|
|
public Stream MakeReportFromBlocks(DailyReportDto dto)
|
2022-06-17 13:20:48 +05:00
|
|
|
|
{
|
|
|
|
|
using var workbook = new XLWorkbook();
|
2022-06-30 16:01:46 +05:00
|
|
|
|
FillExampleBlocks(workbook, dto);
|
2022-06-17 13:20:48 +05:00
|
|
|
|
MemoryStream memoryStream = new MemoryStream();
|
|
|
|
|
workbook.SaveAs(memoryStream, new SaveOptions { });
|
|
|
|
|
memoryStream.Seek(0, SeekOrigin.Begin);
|
|
|
|
|
return memoryStream;
|
|
|
|
|
}
|
|
|
|
|
|
2022-06-30 16:01:46 +05:00
|
|
|
|
private void FillExampleBlocks(XLWorkbook workbook, DailyReportDto dto)
|
2022-06-24 11:41:46 +05:00
|
|
|
|
{
|
2022-07-05 11:30:25 +05:00
|
|
|
|
var sheet = workbook.Worksheets.Add(dto.Head.ReportDate.ToString("dd.MM.yyyy"));
|
2022-06-24 11:41:46 +05:00
|
|
|
|
var addressStart = new CellAddress(sheet, 1, 1);
|
2022-07-05 11:30:25 +05:00
|
|
|
|
var blockHeader = new HeadBlock(addressStart, dto.Head);
|
2022-06-24 11:41:46 +05:00
|
|
|
|
addressStart = blockHeader.AddressBlockEnd + (1, 0);
|
2022-07-04 05:29:16 +05:00
|
|
|
|
addressStart.ColumnNumber = 1;
|
2022-07-05 11:30:25 +05:00
|
|
|
|
var blockBha = new BhaBlock(addressStart, dto.Bha);
|
2022-06-29 13:04:30 +05:00
|
|
|
|
addressStart = blockBha.AddressBlockEnd + (1, 0);
|
2022-07-04 05:29:16 +05:00
|
|
|
|
addressStart.ColumnNumber = 1;
|
2022-07-05 11:30:25 +05:00
|
|
|
|
var timeBalance = new TimeBalanceBlock(addressStart, dto.TimeBalance);
|
2022-06-30 16:01:46 +05:00
|
|
|
|
addressStart = timeBalance.AddressBlockEnd + (1, 0);
|
2022-07-04 05:29:16 +05:00
|
|
|
|
addressStart.ColumnNumber = 1;
|
2022-07-05 11:30:25 +05:00
|
|
|
|
var blockDimensionless = new DimensionlessBlock(addressStart, dto.Dimensionless);
|
2022-06-30 16:01:46 +05:00
|
|
|
|
addressStart = blockDimensionless.AddressBlockEnd + (1, 0);
|
2022-07-04 05:29:16 +05:00
|
|
|
|
addressStart.ColumnNumber = 1;
|
2022-07-05 11:30:25 +05:00
|
|
|
|
var blockSaub = new SaubBlock(addressStart, dto.Saub);
|
2022-07-04 05:29:16 +05:00
|
|
|
|
addressStart = blockSaub.AddressBlockEnd + (1, 0);
|
2022-07-05 11:30:25 +05:00
|
|
|
|
blockDimensionless.SaubBlock = blockSaub;
|
2022-07-04 05:29:16 +05:00
|
|
|
|
addressStart.ColumnNumber = 1;
|
2022-07-05 11:30:25 +05:00
|
|
|
|
var blockSign = new SignBlock(addressStart, dto.Sign);
|
2022-06-30 16:01:46 +05:00
|
|
|
|
addressStart = blockSign.AddressBlockEnd + (1, 0);
|
2022-07-04 05:29:16 +05:00
|
|
|
|
addressStart.ColumnNumber = 1;
|
2022-06-24 11:41:46 +05:00
|
|
|
|
blockHeader.Draw(sheet);
|
2022-06-29 13:04:30 +05:00
|
|
|
|
blockBha.Draw(sheet);
|
|
|
|
|
timeBalance.Draw(sheet);
|
2022-06-30 16:01:46 +05:00
|
|
|
|
blockDimensionless.Draw(sheet);
|
2022-07-04 05:29:16 +05:00
|
|
|
|
blockSaub.Draw(sheet);
|
2022-06-30 16:01:46 +05:00
|
|
|
|
blockSign.Draw(sheet);
|
2022-07-04 05:29:16 +05:00
|
|
|
|
}
|
2022-04-29 15:39:12 +05:00
|
|
|
|
}
|
|
|
|
|
}
|
2022-06-17 13:20:48 +05:00
|
|
|
|
|