// 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.Controls.DataGrid; using Core.Common.Controls.Views; using Core.Common.Util; using Ringtoets.Common.Data.FailureMechanism; using Ringtoets.Common.Forms.Properties; namespace Ringtoets.Common.Forms.Views { /// /// The view for the . /// /// The type of the failure mechanism this view belongs to. /// The type of results which are presented by the /// . public abstract partial class FailureMechanismResultView : UserControl, IView where TSectionResult : FailureMechanismSectionResult where TFailureMechanism : FailureMechanismBase { protected const int AssessmentLayerOneColumnIndex = 1; private readonly Observer failureMechanismSectionResultObserver; private readonly IObservableEnumerable failureMechanismSectionResults; private readonly RecursiveObserver, TSectionResult> failureMechanismSectionResultsObserver; /// /// Creates a new instance of . /// /// The failure mechanism this view belongs to. /// The collection of to /// show in the view. /// Thrown when any input parameter is null. protected FailureMechanismResultView(TFailureMechanism failureMechanism, IObservableEnumerable failureMechanismSectionResults) { if (failureMechanism == null) { throw new ArgumentNullException(nameof(failureMechanism)); } if (failureMechanismSectionResults == null) { throw new ArgumentNullException(nameof(failureMechanismSectionResults)); } InitializeComponent(); FailureMechanism = failureMechanism; this.failureMechanismSectionResults = failureMechanismSectionResults; failureMechanismSectionResultObserver = new Observer(UpdateDataGridViewDataSource) { Observable = failureMechanismSectionResults }; failureMechanismSectionResultsObserver = new RecursiveObserver, TSectionResult>( DataGridViewControl.RefreshDataGridView, sr => sr) { Observable = failureMechanismSectionResults }; } /// /// Gets the failure mechanism. /// public TFailureMechanism FailureMechanism { get; } public object Data { get; set; } protected DataGridViewControl DataGridViewControl { get; private set; } protected override void OnLoad(EventArgs e) { base.OnLoad(e); AddDataGridColumns(); } /// /// Creates a display object for which is added to the /// on the . /// /// The for which to create a /// display object. /// A display object which can be added as a row to the . protected abstract object CreateFailureMechanismSectionResultRow(TSectionResult sectionResult); protected override void Dispose(bool disposing) { failureMechanismSectionResultObserver?.Dispose(); failureMechanismSectionResultsObserver?.Dispose(); if (disposing) { components?.Dispose(); } base.Dispose(disposing); } /// /// Finds out whether the assessment section which is represented by the row at index /// has passed the simple assessment. /// /// The index of the row which has a section attached. /// false if the simple assessment has passed, true otherwise. protected bool HasPassedSimpleAssessment(int rowIndex) { return (AssessmentLayerOneState) DataGridViewControl.GetCell(rowIndex, AssessmentLayerOneColumnIndex).Value == AssessmentLayerOneState.Sufficient; } /// /// Updates the data source of the data grid view with the current known failure mechanism section results. /// protected void UpdateDataGridViewDataSource() { DataGridViewControl.EndEdit(); DataGridViewControl.SetDataSource( failureMechanismSectionResults .Select(CreateFailureMechanismSectionResultRow) .Where(sr => sr != null) .ToList() ); } /// /// Gets data that is visualized on the row a the given . /// /// The position of the row in the data source. /// The data bound to the row at index . protected object GetDataAtRow(int rowIndex) { return DataGridViewControl.GetRowFromIndex(rowIndex).DataBoundItem; } /// /// Adds the column for the section name in the view. /// protected virtual void AddDataGridColumns() { DataGridViewControl.AddTextBoxColumn( nameof(FailureMechanismSectionResultRow.Name), Resources.FailureMechanismResultView_InitializeDataGridView_Section_name, true); } } }