2024-02-01 16:35:29 +05:00
|
|
|
|
using System;
|
|
|
|
|
using AsbCloudApp.Data;
|
2024-01-29 15:03:53 +05:00
|
|
|
|
using AsbCloudApp.Data.Trajectory;
|
|
|
|
|
using ClosedXML.Excel;
|
|
|
|
|
|
|
|
|
|
namespace AsbCloudInfrastructure.Services.Trajectory.Parser;
|
|
|
|
|
|
2024-02-08 14:50:14 +05:00
|
|
|
|
public class TrajectoryPlanParser : TrajectoryParser<TrajectoryGeoPlanDto>
|
2024-01-29 15:03:53 +05:00
|
|
|
|
{
|
2024-01-31 17:20:54 +05:00
|
|
|
|
protected override string SheetName => "Плановая траектория";
|
2024-02-01 16:35:29 +05:00
|
|
|
|
protected override string TemplateFileName => "TrajectoryPlanTemplate.xlsx";
|
2024-01-31 17:20:54 +05:00
|
|
|
|
|
2024-02-08 14:50:14 +05:00
|
|
|
|
public TrajectoryPlanParser(IServiceProvider serviceProvider)
|
2024-02-01 16:35:29 +05:00
|
|
|
|
: base(serviceProvider)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2024-01-29 15:03:53 +05:00
|
|
|
|
protected override ValidationResultDto<TrajectoryGeoPlanDto> ParseRow(IXLRow row)
|
|
|
|
|
{
|
|
|
|
|
var trajectoryRow = new TrajectoryGeoPlanDto
|
|
|
|
|
{
|
|
|
|
|
WellboreDepth = row.Cell(1).GetCellValue<double>(),
|
|
|
|
|
ZenithAngle = row.Cell(2).GetCellValue<double>(),
|
|
|
|
|
AzimuthGeo = row.Cell(3).GetCellValue<double>(),
|
|
|
|
|
AzimuthMagnetic = row.Cell(4).GetCellValue<double>(),
|
|
|
|
|
VerticalDepth = row.Cell(5).GetCellValue<double>(),
|
|
|
|
|
Radius = row.Cell(6).GetCellValue<double>(),
|
|
|
|
|
Comment = row.Cell(7).GetCellValue<string?>()
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
//TODO: Добавить валидацию модели
|
|
|
|
|
|
2024-02-01 16:35:29 +05:00
|
|
|
|
var validationResult = new ValidationResultDto<TrajectoryGeoPlanDto>
|
2024-01-29 15:03:53 +05:00
|
|
|
|
{
|
|
|
|
|
Item = trajectoryRow
|
|
|
|
|
};
|
2024-02-01 16:35:29 +05:00
|
|
|
|
|
|
|
|
|
return validationResult;
|
2024-01-29 15:03:53 +05:00
|
|
|
|
}
|
|
|
|
|
}
|