// 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 System.ComponentModel; using Ringtoets.Common.Data.AssessmentSection; using Ringtoets.Common.Data.FailureMechanism; using Ringtoets.Common.Data.Structures; using Ringtoets.Common.Forms.TypeConverters; using Ringtoets.Common.Forms.Views; using Ringtoets.StabilityPointStructures.Data; namespace Ringtoets.StabilityPointStructures.Forms.Views { /// /// This class represents a row of for stability point structures /// public class StabilityPointStructuresFailureMechanismSectionResultRow : FailureMechanismSectionResultRow { private readonly StabilityPointStructuresFailureMechanism failureMechanism; private readonly IAssessmentSection assessmentSection; /// /// Creates a new instance of . /// /// The to wrap /// so that it can be displayed as a row. /// The failure mechanism the result belongs to. /// The assessment section the result belongs to. /// Thrown when any parameter is null. public StabilityPointStructuresFailureMechanismSectionResultRow(StabilityPointStructuresFailureMechanismSectionResult sectionResult, StabilityPointStructuresFailureMechanism failureMechanism, IAssessmentSection assessmentSection) : base(sectionResult) { if (failureMechanism == null) { throw new ArgumentNullException(nameof(failureMechanism)); } if (assessmentSection == null) { throw new ArgumentNullException(nameof(assessmentSection)); } this.failureMechanism = failureMechanism; this.assessmentSection = assessmentSection; } /// /// Gets or sets the value representing whether the section passed the layer 1 assessment. /// public AssessmentLayerOneState AssessmentLayerOne { get { return SectionResult.AssessmentLayerOne; } set { SectionResult.AssessmentLayerOne = value; SectionResult.NotifyObservers(); } } /// /// Gets the value representing the result of the layer 2a assessment. /// [TypeConverter(typeof(NoProbabilityValueDoubleConverter))] public double AssessmentLayerTwoA { get { return SectionResult.GetAssessmentLayerTwoA(failureMechanism, assessmentSection); } } /// /// Gets or sets the value of the tailored assessment of safety. /// /// Thrown when /// is outside of the valid ranges. [TypeConverter(typeof(NoProbabilityValueDoubleConverter))] public double AssessmentLayerThree { get { return SectionResult.AssessmentLayerThree; } set { SectionResult.AssessmentLayerThree = value; } } /// /// Gets the of the wrapped /// . /// /// null if the wrapped section result does not have a calculation /// set. Otherwise the calculation of the wrapped section result is returned. public StructuresCalculation GetSectionResultCalculation() { return SectionResult.Calculation; } } }