2023-04-03 14:59:59 +05:00
|
|
|
|
using AsbCloudApp.Data.ProcessMap;
|
|
|
|
|
using AsbCloudApp.Services;
|
|
|
|
|
using ClosedXML.Excel;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.IO;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Threading;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
|
|
|
|
namespace AsbCloudInfrastructure.Services.ProcessMap
|
|
|
|
|
{
|
2023-04-18 16:22:53 +05:00
|
|
|
|
|
2023-04-03 14:59:59 +05:00
|
|
|
|
public class ProcessMapReportMakerService : IProcessMapReportMakerService
|
|
|
|
|
{
|
|
|
|
|
const int firstColumn = 2;
|
2023-08-21 12:11:32 +05:00
|
|
|
|
const int lastColumn = 42;
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
2023-04-06 16:20:21 +05:00
|
|
|
|
const int headerRowsCount = 5;
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
2023-09-05 16:23:40 +05:00
|
|
|
|
private readonly IProcessMapService processMapService;
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
2023-09-05 16:23:40 +05:00
|
|
|
|
public ProcessMapReportMakerService(IProcessMapService processMapService)
|
2023-04-03 14:59:59 +05:00
|
|
|
|
{
|
|
|
|
|
this.processMapService = processMapService;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<Stream> MakeReportAsync(int idWell, CancellationToken token)
|
|
|
|
|
{
|
|
|
|
|
var stream = GetExcelTemplateStream();
|
|
|
|
|
using var workbook = new XLWorkbook(stream, XLEventTracking.Disabled);
|
|
|
|
|
|
2023-04-06 10:25:51 +05:00
|
|
|
|
var data = await processMapService.GetProcessMapReportAsync(idWell, token);
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
|
|
|
|
FillProcessMapToWorkbook(workbook, data);
|
|
|
|
|
|
|
|
|
|
MemoryStream memoryStream = new MemoryStream();
|
|
|
|
|
workbook.SaveAs(memoryStream, new SaveOptions { });
|
|
|
|
|
memoryStream.Seek(0, SeekOrigin.Begin);
|
|
|
|
|
return memoryStream;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void FillProcessMapToWorkbook(XLWorkbook workbook, IEnumerable<ProcessMapReportDto> data)
|
|
|
|
|
{
|
|
|
|
|
var sheet = workbook.Worksheets.FirstOrDefault();
|
|
|
|
|
if (sheet is null)
|
|
|
|
|
return;
|
|
|
|
|
var dataBySections = data.GroupBy(p => p.IdWellSectionType);
|
|
|
|
|
FillSheet(sheet, dataBySections);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void FillSheet(IXLWorksheet sheet, IEnumerable<IGrouping<int, ProcessMapReportDto>> dataBySections)
|
|
|
|
|
{
|
|
|
|
|
var startRow = headerRowsCount + 1;
|
|
|
|
|
foreach (var sectionData in dataBySections)
|
|
|
|
|
{
|
|
|
|
|
if(sectionData.Any())
|
|
|
|
|
startRow = FillSection(sheet, sectionData, startRow);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static int FillSection(IXLWorksheet sheet, IGrouping<int, ProcessMapReportDto> sectionData, int row)
|
|
|
|
|
{
|
|
|
|
|
var rowStart = row;
|
|
|
|
|
|
|
|
|
|
var sectionName = sectionData.FirstOrDefault()?.WellSectionTypeName
|
|
|
|
|
?? sectionData.Key.ToString();
|
|
|
|
|
|
|
|
|
|
sheet.Range(row, firstColumn, row, lastColumn)
|
|
|
|
|
.Merge()
|
|
|
|
|
.FirstCell()
|
|
|
|
|
.SetVal(sectionName)
|
|
|
|
|
.Style
|
|
|
|
|
.Fill.SetBackgroundColor(XLColor.LightGray);
|
|
|
|
|
|
|
|
|
|
row++;
|
|
|
|
|
|
|
|
|
|
foreach (var interval in sectionData)
|
|
|
|
|
row = FillIntervalData(sheet, interval, row);
|
|
|
|
|
|
|
|
|
|
var sectionStyle = sheet.Range(rowStart, firstColumn, row - 1, lastColumn).Style;
|
|
|
|
|
SetBorders(sectionStyle);
|
|
|
|
|
return row;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static int FillIntervalData(IXLWorksheet sheet, ProcessMapReportDto interval, int row)
|
|
|
|
|
{
|
|
|
|
|
const int columnDepth = firstColumn + 1;
|
|
|
|
|
const int columnDate = firstColumn + 2;
|
|
|
|
|
const int columnRopTime = firstColumn + 3;
|
|
|
|
|
const int columnMode = firstColumn + 4;
|
|
|
|
|
|
2023-04-06 15:18:29 +05:00
|
|
|
|
sheet.Cell(row, firstColumn)
|
|
|
|
|
.SetVal(interval.DepthStart, "0.0");
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
2023-04-06 15:18:29 +05:00
|
|
|
|
sheet.Cell(row, columnDepth)
|
|
|
|
|
.SetVal(interval.DepthEnd, "0.0");
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
2023-04-06 15:18:29 +05:00
|
|
|
|
sheet.Cell(row, columnDate)
|
2023-04-03 14:59:59 +05:00
|
|
|
|
.SetVal(interval.DateStart);
|
|
|
|
|
|
2023-04-06 15:18:29 +05:00
|
|
|
|
sheet.Cell(row, columnRopTime)
|
2023-04-03 14:59:59 +05:00
|
|
|
|
.SetVal(interval.MechDrillingHours);
|
|
|
|
|
|
2023-04-06 15:18:29 +05:00
|
|
|
|
row = FillIntervalModeData(sheet, interval, columnMode, row);
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
|
|
|
|
return row;
|
|
|
|
|
}
|
|
|
|
|
|
2023-04-06 15:18:29 +05:00
|
|
|
|
private static int FillIntervalModeData(IXLWorksheet sheet, ProcessMapReportDto modeData, int column, int row)
|
|
|
|
|
{
|
|
|
|
|
int columnDeltaDepth = column + 1;
|
|
|
|
|
int columnPressure = columnDeltaDepth + 1;
|
|
|
|
|
int columnLoad = columnPressure + 5;
|
|
|
|
|
int columnTorque = columnLoad + 5;
|
|
|
|
|
int columnSpeed = columnTorque + 5;
|
|
|
|
|
int columnUsagePlan = columnSpeed + 5;
|
|
|
|
|
int columnUsageFact = columnUsagePlan + 1;
|
|
|
|
|
int columnRop = columnUsageFact + 12;
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
2023-04-06 15:18:29 +05:00
|
|
|
|
sheet.Cell(row, column)
|
|
|
|
|
.SetVal(modeData.DrillingMode);
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
2023-04-06 15:18:29 +05:00
|
|
|
|
sheet.Cell(row, columnDeltaDepth)
|
|
|
|
|
.SetVal(modeData.DeltaDepth);
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
2023-04-06 15:18:29 +05:00
|
|
|
|
FillIntervalModeDataParam(sheet, modeData.PressureDiff, columnPressure, row);
|
|
|
|
|
FillIntervalModeDataParam(sheet, modeData.AxialLoad, columnLoad, row);
|
|
|
|
|
FillIntervalModeDataParam(sheet, modeData.TopDriveTorque, columnTorque, row);
|
|
|
|
|
FillIntervalModeDataSpeed(sheet, modeData.SpeedLimit, columnSpeed, row);
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
2023-04-06 15:18:29 +05:00
|
|
|
|
sheet.Cell(row, columnUsagePlan)
|
2023-04-06 17:27:31 +05:00
|
|
|
|
.SetVal(modeData.UsagePlan);
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
2023-04-06 15:18:29 +05:00
|
|
|
|
sheet.Cell(row, columnUsageFact)
|
2023-04-06 17:27:31 +05:00
|
|
|
|
.SetVal(modeData.UsageFact);
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
2023-04-06 15:18:29 +05:00
|
|
|
|
sheet.Cell(row, columnRop)
|
|
|
|
|
.SetVal(modeData.Rop);
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
2023-04-06 15:18:29 +05:00
|
|
|
|
return row + 1;
|
|
|
|
|
}
|
2023-04-03 14:59:59 +05:00
|
|
|
|
|
|
|
|
|
private static void FillIntervalModeDataParam(IXLWorksheet sheet, ProcessMapReportParamsDto dataParam, int column, int row)
|
|
|
|
|
{
|
|
|
|
|
const int columnOffsetSpPlan = 0;
|
|
|
|
|
const int columnOffsetSpFact = 1;
|
|
|
|
|
const int columnOffsetFact = 2;
|
|
|
|
|
const int columnOffsetLimit = 3;
|
|
|
|
|
const int columnOffsetPercent = 4;
|
|
|
|
|
|
|
|
|
|
sheet.Cell(row, column + columnOffsetSpPlan)
|
|
|
|
|
.SetVal(dataParam.SetpointPlan);
|
|
|
|
|
|
|
|
|
|
sheet.Cell(row, column + columnOffsetSpFact)
|
|
|
|
|
.SetVal(dataParam.SetpointFact);
|
|
|
|
|
|
|
|
|
|
sheet.Cell(row, column + columnOffsetFact)
|
|
|
|
|
.SetVal(dataParam.Fact);
|
|
|
|
|
|
|
|
|
|
sheet.Cell(row, column + columnOffsetLimit)
|
|
|
|
|
.SetVal(dataParam.Limit);
|
|
|
|
|
|
|
|
|
|
sheet.Cell(row, column + columnOffsetPercent)
|
2023-04-17 15:34:40 +05:00
|
|
|
|
.SetVal(dataParam.SetpointUsage, format: "0.0");
|
2023-04-03 14:59:59 +05:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void FillIntervalModeDataSpeed(IXLWorksheet sheet, ProcessMapReportParamsDto dataParam, int column, int row)
|
|
|
|
|
{
|
|
|
|
|
const int columnOffsetSpPlan = 0;
|
|
|
|
|
const int columnOffsetSpFact = 1;
|
|
|
|
|
const int columnOffsetFact = 2;
|
|
|
|
|
const int columnOffsetLimit = 3;
|
|
|
|
|
const int columnOffsetPercent = 4;
|
|
|
|
|
|
|
|
|
|
sheet.Cell(row, column + columnOffsetSpPlan)
|
|
|
|
|
.SetVal(dataParam.SetpointPlan);
|
|
|
|
|
|
|
|
|
|
sheet.Cell(row, column + columnOffsetSpFact)
|
|
|
|
|
.SetVal(dataParam.SetpointFact);
|
|
|
|
|
|
|
|
|
|
sheet.Cell(row, column + columnOffsetFact)
|
|
|
|
|
.SetVal(dataParam.Fact);
|
|
|
|
|
|
|
|
|
|
sheet.Cell(row, column + columnOffsetLimit)
|
|
|
|
|
.SetVal(dataParam.Limit);
|
|
|
|
|
|
|
|
|
|
sheet.Cell(row, column + columnOffsetPercent)
|
2023-04-17 15:34:40 +05:00
|
|
|
|
.SetVal(dataParam.SetpointUsage, format: "0.0");
|
2023-04-03 14:59:59 +05:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static Stream GetExcelTemplateStream()
|
|
|
|
|
{
|
|
|
|
|
var stream = System.Reflection.Assembly.GetExecutingAssembly()
|
|
|
|
|
.GetManifestResourceStream("AsbCloudInfrastructure.Services.ProcessMap.ProcessMapReportTemplate.xlsx");
|
|
|
|
|
return stream!;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static IXLStyle SetBorders(IXLStyle style)
|
|
|
|
|
{
|
|
|
|
|
style.Border.RightBorder = XLBorderStyleValues.Thin ;
|
|
|
|
|
style.Border.LeftBorder = XLBorderStyleValues.Thin;
|
|
|
|
|
style.Border.TopBorder = XLBorderStyleValues.Thin ;
|
|
|
|
|
style.Border.BottomBorder = XLBorderStyleValues.Thin ;
|
|
|
|
|
style.Border.InsideBorder = XLBorderStyleValues.Thin ;
|
|
|
|
|
return style;
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-04-18 16:22:53 +05:00
|
|
|
|
|
2023-04-03 14:59:59 +05:00
|
|
|
|
}
|