// 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.Collections.Generic;
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;
protected IEnumerable SectionResultRows;
///
/// 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>(
UpdateSectionResultRows,
sr => sr)
{
Observable = failureMechanismSectionResults
};
}
///
/// Gets the failure mechanism.
///
public TFailureMechanism FailureMechanism { get; }
public object Data { get; set; }
protected DataGridViewControl DataGridViewControl { get; private set; }
///
/// Updates the section result rows whenever a section result is notified.
///
protected virtual void UpdateSectionResultRows()
{
DataGridViewControl.RefreshDataGridView();
}
protected override void OnLoad(EventArgs e)
{
base.OnLoad(e);
AddDataGridColumns();
BindEvents();
UpdateDataGridViewDataSource();
}
///
/// 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();
DataGridViewControl.CellFormatting -= HandleCellStyling;
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();
SectionResultRows = failureMechanismSectionResults
.Select(CreateFailureMechanismSectionResultRow)
.Where(sr => sr != null)
.ToList();
DataGridViewControl.SetDataSource(SectionResultRows);
UpdateSectionResultRows();
}
///
/// 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 TSectionResultRow GetDataAtRow(int rowIndex)
{
return (TSectionResultRow) DataGridViewControl.GetRowFromIndex(rowIndex).DataBoundItem;
}
///
/// Adds the columns to the view.
///
protected abstract void AddDataGridColumns();
///
/// Binds the events to the data grid view.
///
protected virtual void BindEvents()
{
DataGridViewControl.CellFormatting += HandleCellStyling;
}
private void HandleCellStyling(object sender, DataGridViewCellFormattingEventArgs e)
{
TSectionResultRow row = GetDataAtRow(e.RowIndex);
if (row.ColumnStateDefinitions.ContainsKey(e.ColumnIndex))
{
DataGridViewColumnStateDefinition columnStateDefinition = row.ColumnStateDefinitions[e.ColumnIndex];
DataGridViewCell cell = DataGridViewControl.GetCell(e.RowIndex, e.ColumnIndex);
cell.ReadOnly = columnStateDefinition.ReadOnly;
cell.ErrorText = columnStateDefinition.ErrorText;
cell.Style.BackColor = columnStateDefinition.Style.BackgroundColor;
cell.Style.ForeColor = columnStateDefinition.Style.TextColor;
}
}
}
}