// 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.Linq; using System.Windows.Forms; using Core.Common.Base; using Core.Common.Util; using Ringtoets.Common.Data.AssessmentSection; using Ringtoets.Common.Data.Calculation; using Ringtoets.Common.Forms.Helpers; using Ringtoets.Common.Forms.Views; using Ringtoets.Common.Primitives; using Ringtoets.MacroStabilityInwards.Data; using RingtoetsCommonFormsResources = Ringtoets.Common.Forms.Properties.Resources; namespace Ringtoets.MacroStabilityInwards.Forms.Views { /// /// The view for the . /// public class MacroStabilityInwardsFailureMechanismResultView : FailureMechanismResultView { private const int detailedAssessmentIndex = 2; private const double tolerance = 1e-6; private readonly RecursiveObserver calculationInputObserver; private readonly RecursiveObserver calculationOutputObserver; private readonly RecursiveObserver calculationGroupObserver; private readonly Observer failureMechanismObserver; private readonly IAssessmentSection assessmentSection; /// /// /// Creates a new instance of . /// /// The assessment section that the failure mechanism belongs to. public MacroStabilityInwardsFailureMechanismResultView( IObservableEnumerable failureMechanismSectionResults, MacroStabilityInwardsFailureMechanism failureMechanism, IAssessmentSection assessmentSection) : base(failureMechanismSectionResults, failureMechanism) { if (assessmentSection == null) { throw new ArgumentNullException(nameof(assessmentSection)); } failureMechanismObserver = new Observer(UpdateDataGridViewDataSource) { Observable = failureMechanism }; this.assessmentSection = assessmentSection; DataGridViewControl.CellFormatting += ShowDetailedAssessmentErrors; DataGridViewControl.CellFormatting += DisableIrrelevantFieldsFormatting; // The concat is needed to observe the input of calculations in child groups. calculationInputObserver = new RecursiveObserver( UpdateDataGridViewDataSource, cg => cg.Children.Concat(cg.Children .OfType() .Select(c => c.InputParameters))); calculationOutputObserver = new RecursiveObserver( UpdateDataGridViewDataSource, cg => cg.Children.Concat(cg.Children .OfType() .Select(c => c.Output))); calculationGroupObserver = new RecursiveObserver( UpdateDataGridViewDataSource, c => c.Children); CalculationGroup observableGroup = failureMechanism.CalculationsGroup; calculationInputObserver.Observable = observableGroup; calculationOutputObserver.Observable = observableGroup; calculationGroupObserver.Observable = observableGroup; UpdateDataGridViewDataSource(); } protected override void Dispose(bool disposing) { DataGridViewControl.CellFormatting -= ShowDetailedAssessmentErrors; DataGridViewControl.CellFormatting -= DisableIrrelevantFieldsFormatting; calculationInputObserver.Dispose(); calculationOutputObserver.Dispose(); calculationGroupObserver.Dispose(); failureMechanismObserver.Dispose(); base.Dispose(disposing); } protected override object CreateFailureMechanismSectionResultRow(MacroStabilityInwardsFailureMechanismSectionResult sectionResult) { return new MacroStabilityInwardsFailureMechanismSectionResultRow(sectionResult, FailureMechanism.Calculations.OfType(), FailureMechanism, assessmentSection); } protected override void AddDataGridColumns() { base.AddDataGridColumns(); EnumDisplayWrapper[] simpleAssessmentDataSource = Enum.GetValues(typeof(SimpleAssessmentResultType)) .OfType() .Select(sa => new EnumDisplayWrapper(sa)) .ToArray(); DataGridViewControl.AddComboBoxColumn( nameof(MacroStabilityInwardsFailureMechanismSectionResultRow.SimpleAssessmentResult), RingtoetsCommonFormsResources.FailureMechanismResultView_SimpleAssessmentResult_DisplayName, simpleAssessmentDataSource, nameof(EnumDisplayWrapper.Value), nameof(EnumDisplayWrapper.DisplayName)); DataGridViewControl.AddTextBoxColumn( nameof(MacroStabilityInwardsFailureMechanismSectionResultRow.DetailedAssessmentProbability), RingtoetsCommonFormsResources.FailureMechanismResultView_DetailedAssessment_DisplayName, true); DataGridViewControl.AddTextBoxColumn( nameof(MacroStabilityInwardsFailureMechanismSectionResultRow.AssessmentLayerThree), RingtoetsCommonFormsResources.FailureMechanismResultView_TailorMadeAssessment_DisplayName); } #region Event handling private void DisableIrrelevantFieldsFormatting(object sender, DataGridViewCellFormattingEventArgs eventArgs) { if (eventArgs.ColumnIndex > SimpleAssessmentColumnIndex) { var simpleAssessmentResult = (SimpleAssessmentResultType) DataGridViewControl.GetCell(eventArgs.RowIndex, SimpleAssessmentColumnIndex).Value; if (FailureMechanismResultViewHelper.SimpleAssessmentIsSufficient(simpleAssessmentResult)) { DataGridViewControl.DisableCell(eventArgs.RowIndex, eventArgs.ColumnIndex); } else { DataGridViewControl.RestoreCell(eventArgs.RowIndex, eventArgs.ColumnIndex); } } } private void ShowDetailedAssessmentErrors(object sender, DataGridViewCellFormattingEventArgs e) { if (e.ColumnIndex != detailedAssessmentIndex) { return; } DataGridViewCell currentDataGridViewCell = DataGridViewControl.GetCell(e.RowIndex, e.ColumnIndex); var resultRow = (MacroStabilityInwardsFailureMechanismSectionResultRow) GetDataAtRow(e.RowIndex); MacroStabilityInwardsFailureMechanismSectionResult rowObject = resultRow.GetSectionResult; if (rowObject.SimpleAssessmentResult == SimpleAssessmentResultType.ProbabilityNegligible || rowObject.SimpleAssessmentResult == SimpleAssessmentResultType.NotApplicable) { currentDataGridViewCell.ErrorText = string.Empty; return; } MacroStabilityInwardsCalculationScenario[] relevantScenarios = rowObject.GetCalculationScenarios(FailureMechanism.Calculations.OfType()).ToArray(); bool relevantScenarioAvailable = relevantScenarios.Length != 0; if (!relevantScenarioAvailable) { currentDataGridViewCell.ErrorText = RingtoetsCommonFormsResources.FailureMechanismResultView_DataGridViewCellFormatting_Not_any_calculation_set; return; } if (Math.Abs(rowObject.GetTotalContribution(relevantScenarios) - 1.0) > tolerance) { currentDataGridViewCell.ErrorText = RingtoetsCommonFormsResources.FailureMechanismResultView_DataGridViewCellFormatting_Scenario_contribution_for_this_section_not_100; return; } CalculationScenarioStatus calculationScenarioStatus = rowObject.GetCalculationScenarioStatus(relevantScenarios); if (calculationScenarioStatus == CalculationScenarioStatus.NotCalculated) { currentDataGridViewCell.ErrorText = RingtoetsCommonFormsResources.FailureMechanismResultView_DataGridViewCellFormatting_Not_all_calculations_have_been_executed; return; } if (double.IsNaN(resultRow.DetailedAssessmentProbability)) { currentDataGridViewCell.ErrorText = RingtoetsCommonFormsResources.FailureMechanismResultView_DataGridViewCellFormatting_All_calculations_must_have_valid_output; return; } currentDataGridViewCell.ErrorText = string.Empty; } #endregion } }