// Copyright (C) Stichting Deltares 2017. All rights reserved. // // This file is part of Ringtoets. // // Ringtoets is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . // // All names, logos, and references to "Deltares" are registered trademarks of // Stichting Deltares and remain full property of Stichting Deltares at all times. // All rights reserved. using System; using Application.Ringtoets.Storage.DbContext; using Core.Common.Utils.Extensions; using Ringtoets.Piping.Data; namespace Application.Ringtoets.Storage.Create.Piping { /// /// Extension methods for related to creating /// a . /// internal static class PipingCalculationScenarioCreateExtensions { /// /// Creates a based on the information of the . /// /// The piping calculation to create a database entity for. /// The object keeping track of create operations. /// The index at which resides within its parent. /// A new . /// Thrown when is null. internal static PipingCalculationEntity Create(this PipingCalculationScenario calculation, PersistenceRegistry registry, int order) { if (registry == null) { throw new ArgumentNullException(nameof(registry)); } var entity = new PipingCalculationEntity { RelevantForScenario = Convert.ToByte(calculation.IsRelevant), ScenarioContribution = calculation.Contribution.ToNaNAsNull(), Name = calculation.Name.DeepClone(), Comments = calculation.Comments.Body.DeepClone(), Order = order }; SetInputParametersToEntity(entity, calculation.InputParameters, registry); AddEntityForPipingOutput(entity, calculation.Output); AddEntityForPipingSemiProbabilisticOutput(entity, calculation.SemiProbabilisticOutput); return entity; } private static void SetInputParametersToEntity(PipingCalculationEntity entity, PipingInput inputParameters, PersistenceRegistry registry) { if (inputParameters.SurfaceLine != null) { entity.SurfaceLineEntity = registry.Get(inputParameters.SurfaceLine); } bool useAssessmentLevelManualInput = inputParameters.UseAssessmentLevelManualInput; entity.UseAssessmentLevelManualInput = Convert.ToByte(useAssessmentLevelManualInput); if (useAssessmentLevelManualInput) { entity.AssessmentLevel = inputParameters.AssessmentLevel.ToNaNAsNull(); } else { if (inputParameters.HydraulicBoundaryLocation != null) { entity.HydraulicLocationEntity = registry.Get(inputParameters.HydraulicBoundaryLocation); } entity.AssessmentLevel = null; } if (inputParameters.StochasticSoilProfile != null) { entity.PipingStochasticSoilProfileEntity = registry.Get(inputParameters.StochasticSoilProfile); } entity.ExitPointL = inputParameters.ExitPointL.Value.ToNaNAsNull(); entity.EntryPointL = inputParameters.EntryPointL.Value.ToNaNAsNull(); entity.PhreaticLevelExitMean = inputParameters.PhreaticLevelExit.Mean.ToNaNAsNull(); entity.PhreaticLevelExitStandardDeviation = inputParameters.PhreaticLevelExit.StandardDeviation.ToNaNAsNull(); entity.DampingFactorExitMean = inputParameters.DampingFactorExit.Mean.ToNaNAsNull(); entity.DampingFactorExitStandardDeviation = inputParameters.DampingFactorExit.StandardDeviation.ToNaNAsNull(); } private static void AddEntityForPipingOutput(PipingCalculationEntity entity, PipingOutput output) { if (output != null) { entity.PipingCalculationOutputEntities.Add(output.Create()); } } private static void AddEntityForPipingSemiProbabilisticOutput(PipingCalculationEntity entity, PipingSemiProbabilisticOutput output) { if (output != null) { entity.PipingSemiProbabilisticOutputEntities.Add(output.Create()); } } } }