using DataAccess.DTOs.Converters; using StructureHelperCommon.Infrastructures.Interfaces; using StructureHelperCommon.Infrastructures.Settings; using StructureHelperCommon.Models; using StructureHelperCommon.Models.Analyses; using StructureHelperCommon.Models.Loggers; using StructureHelperCommon.Models.Projects; using StructureHelperLogic.Models.Analyses; using StructureHelperLogics.Models.CrossSections; using StructureHelperLogics.NdmCalculations.Analyses.ByForces; using System; using System.Collections.Generic; using System.Linq; using System.Runtime.CompilerServices; using System.Text; using System.Threading.Tasks; namespace DataAccess.DTOs { internal class VisualAnalysisToDTOConvertStrategy : IConvertStrategy { private IConvertStrategy convertStrategy; public Dictionary<(Guid id, Type type), ISaveable> ReferenceDictionary { get; set; } public IShiftTraceLogger TraceLogger { get; set; } public VisualAnalysisToDTOConvertStrategy(IConvertStrategy convertStrategy) { this.convertStrategy = convertStrategy; } public VisualAnalysisToDTOConvertStrategy() : this(new AnalysisToDTOConvertStrategy()) { } public VisualAnalysisDTO Convert(IVisualAnalysis source) { Check(); try { VisualAnalysisDTO visualAnalysisDTO = GetNewAnalysis(source); return visualAnalysisDTO; } catch (Exception ex) { TraceLogger?.AddMessage(LoggerStrings.LogicType(this), TraceLogStatuses.Error); TraceLogger?.AddMessage(ex.Message, TraceLogStatuses.Error); throw; } } private VisualAnalysisDTO GetNewAnalysis(IVisualAnalysis source) { VisualAnalysisDTO visualAnalysisDTO = new() { Id = source.Id }; convertStrategy.ReferenceDictionary = ReferenceDictionary; convertStrategy.TraceLogger = TraceLogger; var convertLogic = new DictionaryConvertStrategy(this, convertStrategy) { ReferenceDictionary = ReferenceDictionary, ConvertStrategy = convertStrategy, TraceLogger = TraceLogger }; visualAnalysisDTO.Analysis = convertLogic.Convert(source.Analysis); return visualAnalysisDTO; } private void Check() { var checkLogic = new CheckConvertLogic(); checkLogic.ConvertStrategy = this; checkLogic.TraceLogger = TraceLogger; checkLogic.Check(); } } }