// 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 Ringtoets.Common.Data.FailureMechanism;
namespace Ringtoets.Common.Forms.Views
{
///
/// The view for the .
///
/// The type of results which are presented by the
/// .
/// The type of the row that is used to show the data.
/// The type of the failure mechanism this view belongs to.
public abstract partial class FailureMechanismResultView : UserControl, IView
where TSectionResult : FailureMechanismSectionResult
where TSectionResultRow : FailureMechanismSectionResultRow
where TFailureMechanism : IFailureMechanism
{
protected const int SimpleAssessmentColumnIndex = 1;
private readonly Observer failureMechanismSectionResultObserver;
private readonly IObservableEnumerable failureMechanismSectionResults;
private readonly RecursiveObserver, TSectionResult> failureMechanismSectionResultsObserver;
///
/// Creates a new instance of .
///
/// The collection of to
/// show in the view.
/// The failure mechanism this view belongs to.
/// Thrown when any parameter is null.
protected FailureMechanismResultView(IObservableEnumerable failureMechanismSectionResults, TFailureMechanism failureMechanism)
{
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 TSectionResultRow CreateFailureMechanismSectionResultRow(TSectionResult sectionResult);
protected override void Dispose(bool disposing)
{
failureMechanismSectionResultObserver.Dispose();
failureMechanismSectionResultsObserver.Dispose();
if (disposing)
{
components?.Dispose();
}
base.Dispose(disposing);
}
///
/// 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 columns to the view.
///
protected abstract void AddDataGridColumns();
}
}