// 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.Collections.Generic; using System.Drawing; using System.Linq; using System.Windows.Forms; using Core.Common.Base; using Core.Common.Base.Data; using Core.Common.Controls.TreeView; using Core.Common.Gui; using Core.Common.Gui.ContextMenu; using Core.Common.Gui.Forms.ProgressDialog; using Core.Common.Gui.Plugin; using Core.Common.Util; using Ringtoets.Common.Data.AssessmentSection; using Ringtoets.Common.Data.Calculation; using Ringtoets.Common.Data.FailureMechanism; using Ringtoets.Common.Data.Probability; using Ringtoets.Common.Forms.ChangeHandlers; using Ringtoets.Common.Forms.ExportInfos; using Ringtoets.Common.Forms.Helpers; using Ringtoets.Common.Forms.ImportInfos; using Ringtoets.Common.Forms.PresentationObjects; using Ringtoets.Common.Forms.PropertyClasses; using Ringtoets.Common.Forms.TreeNodeInfos; using Ringtoets.Common.Forms.UpdateInfos; using Ringtoets.Common.Forms.Views; using Ringtoets.Common.IO.FileImporters.MessageProviders; using Ringtoets.Common.IO.SoilProfile; using Ringtoets.Common.IO.SurfaceLines; using Ringtoets.Common.Plugin; using Ringtoets.MacroStabilityInwards.Data; using Ringtoets.MacroStabilityInwards.Data.SoilProfile; using Ringtoets.MacroStabilityInwards.Forms; using Ringtoets.MacroStabilityInwards.Forms.PresentationObjects; using Ringtoets.MacroStabilityInwards.Forms.PropertyClasses; using Ringtoets.MacroStabilityInwards.Forms.Views; using Ringtoets.MacroStabilityInwards.IO.Configurations; using Ringtoets.MacroStabilityInwards.Plugin.FileImporter; using Ringtoets.MacroStabilityInwards.Plugin.Properties; using Ringtoets.MacroStabilityInwards.Primitives; using Ringtoets.MacroStabilityInwards.Service; using RingtoetsCommonFormsResources = Ringtoets.Common.Forms.Properties.Resources; using RingtoetsCommonDataResources = Ringtoets.Common.Data.Properties.Resources; using MacroStabilityInwardsFormsResources = Ringtoets.MacroStabilityInwards.Forms.Properties.Resources; namespace Ringtoets.MacroStabilityInwards.Plugin { /// /// The plug-in for the . /// public class MacroStabilityInwardsPlugin : PluginBase { public override IEnumerable GetPropertyInfos() { yield return new PropertyInfo { CreateInstance = context => new MacroStabilityInwardsFailureMechanismProperties(context.WrappedData) }; yield return new PropertyInfo { CreateInstance = context => new MacroStabilityInwardsInputContextProperties(context, () => GetNormativeAssessmentLevel(context.AssessmentSection, context.MacroStabilityInwardsCalculation), new ObservablePropertyChangeHandler(context.MacroStabilityInwardsCalculation, context.WrappedData)) }; yield return new PropertyInfo { CreateInstance = context => new MacroStabilityInwardsOutputProperties(context.WrappedData.Output, context.FailureMechanism, context.AssessmentSection) }; yield return new PropertyInfo { CreateInstance = context => new MacroStabilityInwardsSurfaceLineCollectionProperties(context.WrappedData) }; yield return new PropertyInfo(); yield return new PropertyInfo { CreateInstance = context => new MacroStabilityInwardsStochasticSoilModelCollectionProperties(context.WrappedData) }; yield return new PropertyInfo { CreateInstance = soilModel => new MacroStabilityInwardsStochasticSoilModelProperties(soilModel) }; yield return new PropertyInfo { CreateInstance = soilProfile => new MacroStabilityInwardsStochasticSoilProfileProperties(soilProfile) }; yield return new PropertyInfo { CreateInstance = context => new FailureMechanismSectionsProbabilityAssessmentProperties( context.WrappedData, ((MacroStabilityInwardsFailureMechanism) context.WrappedData).MacroStabilityInwardsProbabilityAssessmentInput) }; } public override IEnumerable GetImportInfos() { yield return new ImportInfo { Name = RingtoetsCommonDataResources.SurfaceLineCollection_TypeDescriptor, Category = RingtoetsCommonFormsResources.Ringtoets_Category, Image = MacroStabilityInwardsFormsResources.SurfaceLineIcon, FileFilterGenerator = SurfaceLineFileFilter, IsEnabled = context => context.AssessmentSection.ReferenceLine != null, CreateFileImporter = (context, filePath) => new SurfaceLinesCsvImporter( context.WrappedData, filePath, new ImportMessageProvider(), SurfaceLinesCsvImporterConfigurationFactory.CreateReplaceStrategyConfiguration(context.FailureMechanism, context.AssessmentSection.ReferenceLine)), VerifyUpdates = context => VerifySurfaceLineUpdates(context, Resources.MacroStabilityInwardsPlugin_VerifySurfaceLineImports_When_importing_surface_lines_calculation_output_will_be_cleared_confirm) }; yield return new ImportInfo { Name = RingtoetsCommonDataResources.StochasticSoilModelCollection_TypeDescriptor, Category = RingtoetsCommonFormsResources.Ringtoets_Category, Image = MacroStabilityInwardsFormsResources.SoilProfileIcon, FileFilterGenerator = StochasticSoilModelFileFilter, IsEnabled = context => context.AssessmentSection.ReferenceLine != null, CreateFileImporter = (context, filePath) => new StochasticSoilModelImporter( context.WrappedData, filePath, new ImportMessageProvider(), MacroStabilityInwardsStochasticSoilModelImporterConfigurationFactory.CreateReplaceStrategyConfiguration(context.FailureMechanism) ), VerifyUpdates = context => VerifyStochasticSoilModelUpdates(context, Resources.MacroStabilityInwardsPlugin_VerifyStochasticSoilModelImport_When_importing_StochasticSoilModels_calculation_output_will_be_cleared_confirm) }; yield return RingtoetsImportInfoFactory.CreateCalculationConfigurationImportInfo( (context, filePath) => new MacroStabilityInwardsCalculationConfigurationImporter( filePath, context.WrappedData, context.AssessmentSection.HydraulicBoundaryDatabase.Locations, context.FailureMechanism)); } public override IEnumerable GetExportInfos() { yield return RingtoetsExportInfoFactory.CreateCalculationGroupConfigurationExportInfo( (context, filePath) => new MacroStabilityInwardsCalculationConfigurationExporter(context.WrappedData.Children, filePath), context => context.WrappedData.Children.Any()); yield return RingtoetsExportInfoFactory.CreateCalculationConfigurationExportInfo( (context, filePath) => new MacroStabilityInwardsCalculationConfigurationExporter(new[] { context.WrappedData }, filePath)); } public override IEnumerable GetUpdateInfos() { yield return new UpdateInfo { Name = RingtoetsCommonDataResources.SurfaceLineCollection_TypeDescriptor, Category = RingtoetsCommonFormsResources.Ringtoets_Category, Image = MacroStabilityInwardsFormsResources.SurfaceLineIcon, FileFilterGenerator = SurfaceLineFileFilter, IsEnabled = context => context.WrappedData.SourcePath != null, CurrentPath = context => context.WrappedData.SourcePath, CreateFileImporter = (context, filePath) => new SurfaceLinesCsvImporter( context.WrappedData, filePath, new UpdateMessageProvider(), SurfaceLinesCsvImporterConfigurationFactory.CreateUpdateStrategyConfiguration(context.FailureMechanism, context.AssessmentSection.ReferenceLine)), VerifyUpdates = context => VerifySurfaceLineUpdates(context, Resources.MacroStabilityInwardsPlugin_VerifySurfaceLineUpdates_When_updating_surface_lines_definitions_assigned_to_calculation_output_will_be_cleared_confirm) }; yield return new UpdateInfo { Name = RingtoetsCommonDataResources.StochasticSoilModelCollection_TypeDescriptor, Category = RingtoetsCommonFormsResources.Ringtoets_Category, Image = MacroStabilityInwardsFormsResources.SoilProfileIcon, FileFilterGenerator = StochasticSoilModelFileFilter, IsEnabled = context => context.WrappedData.SourcePath != null, CurrentPath = context => context.WrappedData.SourcePath, CreateFileImporter = (context, filePath) => new StochasticSoilModelImporter( context.WrappedData, filePath, new UpdateMessageProvider(), MacroStabilityInwardsStochasticSoilModelImporterConfigurationFactory.CreateUpdateStrategyConfiguration(context.FailureMechanism) ), VerifyUpdates = context => VerifyStochasticSoilModelUpdates( context, Resources.MacroStabilityInwardsPlugin_VerifyStochasticSoilModelUpdates_When_updating_StochasticSoilModel_definitions_assigned_to_calculation_output_will_be_cleared_confirm) }; yield return RingtoetsUpdateInfoFactory.CreateFailureMechanismSectionsUpdateInfo< MacroStabilityInwardsFailureMechanismSectionsContext, MacroStabilityInwardsFailureMechanism, MacroStabilityInwardsFailureMechanismSectionResult>( new MacroStabilityInwardsFailureMechanismSectionResultUpdateStrategy()); } public override IEnumerable GetViewInfos() { yield return new ViewInfo { GetViewName = (view, context) => context.WrappedData.Name, Image = RingtoetsCommonFormsResources.CalculationIcon, CloseForData = CloseFailureMechanismViewForData, AdditionalDataCheck = context => context.WrappedData.IsRelevant, CreateInstance = context => new MacroStabilityInwardsFailureMechanismView(context.WrappedData, context.Parent) }; yield return new ViewInfo< ProbabilityFailureMechanismSectionResultContext, IObservableEnumerable, MacroStabilityInwardsFailureMechanismResultView> { GetViewName = (view, context) => RingtoetsCommonFormsResources.FailureMechanism_AssessmentResult_DisplayName, Image = RingtoetsCommonFormsResources.FailureMechanismSectionResultIcon, CloseForData = CloseFailureMechanismResultViewForData, GetViewData = context => context.WrappedData, CreateInstance = context => new MacroStabilityInwardsFailureMechanismResultView( context.WrappedData, (MacroStabilityInwardsFailureMechanism) context.FailureMechanism, context.AssessmentSection) }; yield return new ViewInfo { GetViewData = context => context.WrappedData, GetViewName = (view, context) => context.WrappedData.Name, Image = RingtoetsCommonFormsResources.GeneralFolderIcon, AdditionalDataCheck = context => context.WrappedData == context.FailureMechanism.CalculationsGroup, CloseForData = CloseCalculationsViewForData, AfterCreate = (view, context) => { view.AssessmentSection = context.AssessmentSection; view.MacroStabilityInwardsFailureMechanism = context.FailureMechanism; } }; yield return new ViewInfo { GetViewData = context => context.MacroStabilityInwardsCalculation, GetViewName = (view, context) => RingtoetsCommonFormsResources.Calculation_Input, Image = RingtoetsCommonFormsResources.GenericInputOutputIcon, CloseForData = CloseInputViewForData, CreateInstance = context => new MacroStabilityInwardsInputView(context.MacroStabilityInwardsCalculation, context.AssessmentSection, () => context.AssessmentSection.GetNormativeHydraulicBoundaryLocationCalculation(context.WrappedData.HydraulicBoundaryLocation)) }; yield return new ViewInfo { GetViewData = context => context.WrappedData, GetViewName = (view, context) => RingtoetsCommonFormsResources.Scenarios_DisplayName, Image = RingtoetsCommonFormsResources.ScenariosIcon, CloseForData = CloseScenariosViewForData, AfterCreate = (view, context) => { view.MacroStabilityInwardsFailureMechanism = context.FailureMechanism; }, CreateInstance = context => new MacroStabilityInwardsScenariosView(context.AssessmentSection) }; yield return new ViewInfo { GetViewData = context => context.WrappedData, GetViewName = (view, context) => RingtoetsCommonFormsResources.CalculationOutput_DisplayName, Image = RingtoetsCommonFormsResources.GeneralOutputIcon, CloseForData = RingtoetsPluginHelper.ShouldCloseViewWithCalculationData, CreateInstance = context => new MacroStabilityInwardsOutputView(context.WrappedData, () => GetNormativeAssessmentLevel(context.AssessmentSection, context.WrappedData)) }; yield return new ViewInfo, FailureMechanismSectionsProbabilityAssessmentView> { GetViewName = (view, context) => RingtoetsCommonFormsResources.FailureMechanismSections_DisplayName, Image = RingtoetsCommonFormsResources.SectionsIcon, CloseForData = RingtoetsPluginHelper.ShouldCloseForFailureMechanismView, CreateInstance = context => new FailureMechanismSectionsProbabilityAssessmentView(context.WrappedData.Sections, context.WrappedData, ((MacroStabilityInwardsFailureMechanism) context.WrappedData).MacroStabilityInwardsProbabilityAssessmentInput), GetViewData = context => context.WrappedData.Sections }; } public override IEnumerable GetTreeNodeInfos() { yield return RingtoetsTreeNodeInfoFactory.CreateFailureMechanismContextTreeNodeInfo( FailureMechanismEnabledChildNodeObjects, FailureMechanismDisabledChildNodeObjects, FailureMechanismEnabledContextMenuStrip, FailureMechanismDisabledContextMenuStrip); yield return RingtoetsTreeNodeInfoFactory.CreateCalculationContextTreeNodeInfo( CalculationContextChildNodeObjects, CalculationContextContextMenuStrip, CalculationContextOnNodeRemoved); yield return RingtoetsTreeNodeInfoFactory.CreateCalculationGroupContextTreeNodeInfo( CalculationGroupContextChildNodeObjects, CalculationGroupContextContextMenuStrip, CalculationGroupContextOnNodeRemoved); yield return new TreeNodeInfo> { Text = context => RingtoetsCommonFormsResources.FailureMechanism_AssessmentResult_DisplayName, Image = context => RingtoetsCommonFormsResources.FailureMechanismSectionResultIcon, ContextMenuStrip = (nodeData, parentData, treeViewControl) => Gui.Get(nodeData, treeViewControl) .AddOpenItem() .Build() }; yield return new TreeNodeInfo { Text = context => RingtoetsCommonFormsResources.Calculation_Input, Image = context => RingtoetsCommonFormsResources.GenericInputOutputIcon, ContextMenuStrip = (nodeData, parentData, treeViewControl) => Gui.Get(nodeData, treeViewControl) .AddOpenItem() .AddSeparator() .AddPropertiesItem() .Build() }; yield return new TreeNodeInfo { Text = context => RingtoetsCommonDataResources.SurfaceLineCollection_TypeDescriptor, Image = context => RingtoetsCommonFormsResources.GeneralFolderIcon, ForeColor = context => context.WrappedData.Any() ? Color.FromKnownColor(KnownColor.ControlText) : Color.FromKnownColor(KnownColor.GrayText), ChildNodeObjects = context => context.WrappedData.Cast().ToArray(), ContextMenuStrip = MacroStabilityInwardsSurfaceLinesContextContextMenuStrip }; yield return new TreeNodeInfo { Text = surfaceLine => surfaceLine.Name, Image = surfaceLine => MacroStabilityInwardsFormsResources.SurfaceLineIcon, ContextMenuStrip = (nodeData, parentData, treeViewControl) => Gui.Get(nodeData, treeViewControl) .AddSeparator() .AddPropertiesItem() .Build() }; yield return new TreeNodeInfo { Text = stochasticSoilModelContext => RingtoetsCommonDataResources.StochasticSoilModelCollection_TypeDescriptor, Image = stochasticSoilModelContext => RingtoetsCommonFormsResources.GeneralFolderIcon, ForeColor = stochasticSoilModelContext => stochasticSoilModelContext.WrappedData.Any() ? Color.FromKnownColor(KnownColor.ControlText) : Color.FromKnownColor(KnownColor.GrayText), ChildNodeObjects = stochasticSoilModelContext => stochasticSoilModelContext.WrappedData.Cast().ToArray(), ContextMenuStrip = StochasticSoilModelCollectionContextContextMenuStrip }; yield return new TreeNodeInfo { Text = stochasticSoilModel => stochasticSoilModel.Name, Image = stochasticSoilModel => MacroStabilityInwardsFormsResources.StochasticSoilModelIcon, ChildNodeObjects = stochasticSoilModel => stochasticSoilModel.StochasticSoilProfiles.Cast().ToArray(), ContextMenuStrip = (nodeData, parentData, treeViewControl) => Gui.Get(nodeData, treeViewControl) .AddCollapseAllItem() .AddExpandAllItem() .AddSeparator() .AddPropertiesItem() .Build() }; yield return new TreeNodeInfo { Text = stochasticSoilProfile => stochasticSoilProfile.SoilProfile != null ? stochasticSoilProfile.SoilProfile.Name : "Profile", Image = stochasticSoilProfile => MacroStabilityInwardsFormsResources.SoilProfileIcon, ContextMenuStrip = (nodeData, parentData, treeViewControl) => Gui.Get(nodeData, treeViewControl) .AddPropertiesItem() .Build() }; yield return new TreeNodeInfo { Text = context => RingtoetsCommonFormsResources.CalculationOutput_DisplayName, Image = context => RingtoetsCommonFormsResources.GeneralOutputIcon, ForeColor = context => context.WrappedData.HasOutput ? Color.FromKnownColor(KnownColor.ControlText) : Color.FromKnownColor(KnownColor.GrayText), ContextMenuStrip = (nodeData, parentData, treeViewControl) => Gui.Get(nodeData, treeViewControl) .AddOpenItem() .AddSeparator() .AddPropertiesItem() .Build() }; yield return new TreeNodeInfo { Text = context => RingtoetsCommonFormsResources.Scenarios_DisplayName, Image = context => RingtoetsCommonFormsResources.ScenariosIcon, ContextMenuStrip = (nodeData, parentData, treeViewControl) => Gui.Get(nodeData, treeViewControl) .AddOpenItem() .Build() }; } private static FileFilterGenerator StochasticSoilModelFileFilter { get { return new FileFilterGenerator(Resources.Soil_file_Extension, Resources.Soil_file_Description); } } private static RoundedDouble GetNormativeAssessmentLevel(IAssessmentSection assessmentSection, MacroStabilityInwardsCalculation calculation) { return assessmentSection.GetNormativeAssessmentLevel(calculation.InputParameters.HydraulicBoundaryLocation); } private bool VerifyStochasticSoilModelUpdates(MacroStabilityInwardsStochasticSoilModelCollectionContext context, string query) { var changeHandler = new FailureMechanismCalculationChangeHandler(context.FailureMechanism, query, new DialogBasedInquiryHelper(Gui.MainWindow)); return !changeHandler.RequireConfirmation() || changeHandler.InquireConfirmation(); } #region MacroStabilityInwardsFailureMechanismView ViewInfo private static bool CloseFailureMechanismViewForData(MacroStabilityInwardsFailureMechanismView view, object o) { var assessmentSection = o as IAssessmentSection; var failureMechanism = o as MacroStabilityInwardsFailureMechanism; return assessmentSection != null ? ReferenceEquals(view.AssessmentSection, assessmentSection) : ReferenceEquals(view.FailureMechanism, failureMechanism); } #endregion #region FailureMechanismResultsView ViewInfo private static bool CloseFailureMechanismResultViewForData(MacroStabilityInwardsFailureMechanismResultView view, object o) { var assessmentSection = o as IAssessmentSection; var failureMechanism = o as MacroStabilityInwardsFailureMechanism; var failureMechanismContext = o as IFailureMechanismContext; if (assessmentSection != null) { return assessmentSection .GetFailureMechanisms() .OfType() .Any(fm => ReferenceEquals(view.FailureMechanism.SectionResults, fm.SectionResults)); } if (failureMechanismContext != null) { failureMechanism = failureMechanismContext.WrappedData; } return failureMechanism != null && ReferenceEquals(view.FailureMechanism.SectionResults, failureMechanism.SectionResults); } #endregion #region MacroStabilityInwardsCalculationsView ViewInfo private static bool CloseCalculationsViewForData(MacroStabilityInwardsCalculationsView view, object o) { var assessmentSection = o as IAssessmentSection; var failureMechanism = o as MacroStabilityInwardsFailureMechanism; var failureMechanismContext = o as MacroStabilityInwardsFailureMechanismContext; if (failureMechanismContext != null) { failureMechanism = failureMechanismContext.WrappedData; } if (assessmentSection != null) { failureMechanism = assessmentSection.GetFailureMechanisms() .OfType() .FirstOrDefault(); } return failureMechanism != null && ReferenceEquals(view.Data, failureMechanism.CalculationsGroup); } #endregion endregion #region MacroStabilityInwardsScenariosView ViewInfo private static bool CloseScenariosViewForData(MacroStabilityInwardsScenariosView view, object o) { var assessmentSection = o as IAssessmentSection; var failureMechanism = o as MacroStabilityInwardsFailureMechanism; var failureMechanismContext = o as MacroStabilityInwardsFailureMechanismContext; if (failureMechanismContext != null) { failureMechanism = failureMechanismContext.WrappedData; } if (assessmentSection != null) { failureMechanism = assessmentSection.GetFailureMechanisms() .OfType() .FirstOrDefault(); } return failureMechanism != null && ReferenceEquals(view.Data, failureMechanism.CalculationsGroup); } #endregion endregion #region MacroStabilityInwardsInputView ViewInfo private static bool CloseInputViewForData(MacroStabilityInwardsInputView view, object o) { var calculationScenarioContext = o as MacroStabilityInwardsCalculationScenarioContext; if (calculationScenarioContext != null) { return ReferenceEquals(view.Data, calculationScenarioContext.WrappedData); } IEnumerable calculations = null; var calculationGroupContext = o as MacroStabilityInwardsCalculationGroupContext; if (calculationGroupContext != null) { calculations = calculationGroupContext.WrappedData.GetCalculations() .OfType(); } var failureMechanism = o as MacroStabilityInwardsFailureMechanism; var failureMechanismContext = o as MacroStabilityInwardsFailureMechanismContext; if (failureMechanismContext != null) { failureMechanism = failureMechanismContext.WrappedData; } var assessmentSection = o as IAssessmentSection; if (assessmentSection != null) { failureMechanism = assessmentSection.GetFailureMechanisms() .OfType() .FirstOrDefault(); } if (failureMechanism != null) { calculations = failureMechanism.CalculationsGroup.GetCalculations() .OfType(); } return calculations != null && calculations.Any(ci => ReferenceEquals(view.Data, ci)); } #endregion private static void ValidateAll(IEnumerable calculations, IAssessmentSection assessmentSection) { foreach (MacroStabilityInwardsCalculation calculation in calculations) { MacroStabilityInwardsCalculationService.Validate(calculation, GetNormativeAssessmentLevel(assessmentSection, calculation)); } } #region MacroStabilityInwardsSurfaceLinesContext TreeNodeInfo private ContextMenuStrip MacroStabilityInwardsSurfaceLinesContextContextMenuStrip(MacroStabilityInwardsSurfaceLinesContext nodeData, object parentData, TreeViewControl treeViewControl) { return Gui.Get(nodeData, treeViewControl) .AddImportItem() .AddUpdateItem() .AddSeparator() .AddCollapseAllItem() .AddExpandAllItem() .AddSeparator() .AddPropertiesItem() .Build(); } #endregion #region MacroStabilityInwardsStochasticSoilModelCollectionContext TreeNodeInfo private ContextMenuStrip StochasticSoilModelCollectionContextContextMenuStrip(MacroStabilityInwardsStochasticSoilModelCollectionContext nodeData, object parentData, TreeViewControl treeViewControl) { return Gui.Get(nodeData, treeViewControl) .AddImportItem() .AddUpdateItem() .AddSeparator() .AddCollapseAllItem() .AddExpandAllItem() .AddSeparator() .AddPropertiesItem() .Build(); } #endregion #region MacroStabilityInwardsFailureMechanismContext TreeNodeInfo private ContextMenuStrip FailureMechanismEnabledContextMenuStrip(MacroStabilityInwardsFailureMechanismContext macroStabilityInwardsFailureMechanismContext, object parentData, TreeViewControl treeViewControl) { var builder = new RingtoetsContextMenuBuilder(Gui.Get(macroStabilityInwardsFailureMechanismContext, treeViewControl)); return builder.AddOpenItem() .AddSeparator() .AddToggleRelevancyOfFailureMechanismItem(macroStabilityInwardsFailureMechanismContext, RemoveAllViewsForItem) .AddSeparator() .AddValidateAllCalculationsInFailureMechanismItem( macroStabilityInwardsFailureMechanismContext, ValidateAll) .AddPerformAllCalculationsInFailureMechanismItem( macroStabilityInwardsFailureMechanismContext, CalculateAll) .AddSeparator() .AddClearAllCalculationOutputInFailureMechanismItem(macroStabilityInwardsFailureMechanismContext.WrappedData) .AddSeparator() .AddCollapseAllItem() .AddExpandAllItem() .AddSeparator() .AddPropertiesItem() .Build(); } private void RemoveAllViewsForItem(MacroStabilityInwardsFailureMechanismContext failureMechanismContext) { Gui.ViewCommands.RemoveAllViewsForItem(failureMechanismContext); } private void CalculateAll(MacroStabilityInwardsFailureMechanismContext context) { ActivityProgressDialogRunner.Run( Gui.MainWindow, MacroStabilityInwardsCalculationActivityFactory.CreateCalculationActivities(context.WrappedData, context.Parent)); } private static void ValidateAll(MacroStabilityInwardsFailureMechanismContext context) { ValidateAll(context.WrappedData.Calculations.OfType(), context.Parent); } private ContextMenuStrip FailureMechanismDisabledContextMenuStrip(MacroStabilityInwardsFailureMechanismContext macroStabilityInwardsFailureMechanismContext, object parentData, TreeViewControl treeViewControl) { var builder = new RingtoetsContextMenuBuilder(Gui.Get(macroStabilityInwardsFailureMechanismContext, treeViewControl)); return builder.AddToggleRelevancyOfFailureMechanismItem(macroStabilityInwardsFailureMechanismContext, RemoveAllViewsForItem) .AddSeparator() .AddCollapseAllItem() .AddExpandAllItem() .AddSeparator() .AddPropertiesItem() .Build(); } private static object[] FailureMechanismEnabledChildNodeObjects(MacroStabilityInwardsFailureMechanismContext macroStabilityInwardsFailureMechanismContext) { MacroStabilityInwardsFailureMechanism wrappedData = macroStabilityInwardsFailureMechanismContext.WrappedData; IAssessmentSection assessmentSection = macroStabilityInwardsFailureMechanismContext.Parent; return new object[] { new CategoryTreeFolder(RingtoetsCommonFormsResources.FailureMechanism_Inputs_DisplayName, GetInputs(wrappedData, assessmentSection), TreeFolderCategory.Input), new MacroStabilityInwardsCalculationGroupContext(wrappedData.CalculationsGroup, null, wrappedData.SurfaceLines, wrappedData.StochasticSoilModels, wrappedData, assessmentSection), new CategoryTreeFolder(RingtoetsCommonFormsResources.FailureMechanism_Outputs_DisplayName, GetOutputs(wrappedData, assessmentSection), TreeFolderCategory.Output) }; } private static object[] FailureMechanismDisabledChildNodeObjects(MacroStabilityInwardsFailureMechanismContext macroStabilityInwardsFailureMechanismContext) { return new object[] { macroStabilityInwardsFailureMechanismContext.WrappedData.NotRelevantComments }; } private static IEnumerable GetInputs(MacroStabilityInwardsFailureMechanism failureMechanism, IAssessmentSection assessmentSection) { return new object[] { new MacroStabilityInwardsFailureMechanismSectionsContext(failureMechanism, assessmentSection), new MacroStabilityInwardsSurfaceLinesContext(failureMechanism.SurfaceLines, failureMechanism, assessmentSection), new MacroStabilityInwardsStochasticSoilModelCollectionContext(failureMechanism.StochasticSoilModels, failureMechanism, assessmentSection), failureMechanism.InputComments }; } private static IEnumerable GetOutputs(MacroStabilityInwardsFailureMechanism failureMechanism, IAssessmentSection assessmentSection) { MacroStabilityInwardsProbabilityAssessmentInput probabilityAssessmentInput = failureMechanism.MacroStabilityInwardsProbabilityAssessmentInput; return new object[] { new FailureMechanismAssemblyCategoriesContext(failureMechanism, assessmentSection, () => probabilityAssessmentInput.GetN(probabilityAssessmentInput.SectionLength)), new MacroStabilityInwardsScenariosContext(failureMechanism.CalculationsGroup, failureMechanism, assessmentSection), new ProbabilityFailureMechanismSectionResultContext(failureMechanism.SectionResults, failureMechanism, assessmentSection), failureMechanism.OutputComments }; } #endregion #region MacroStabilityInwardsCalculationScenarioContext TreeNodeInfo private ContextMenuStrip CalculationContextContextMenuStrip(MacroStabilityInwardsCalculationScenarioContext nodeData, object parentData, TreeViewControl treeViewControl) { var builder = new RingtoetsContextMenuBuilder(Gui.Get(nodeData, treeViewControl)); MacroStabilityInwardsCalculation calculation = nodeData.WrappedData; return builder.AddExportItem() .AddSeparator() .AddDuplicateCalculationItem(calculation, nodeData) .AddSeparator() .AddRenameItem() .AddSeparator() .AddValidateCalculationItem( nodeData, Validate) .AddPerformCalculationItem( calculation, nodeData, PerformCalculation) .AddSeparator() .AddClearCalculationOutputItem(calculation) .AddDeleteItem() .AddSeparator() .AddCollapseAllItem() .AddExpandAllItem() .AddSeparator() .AddPropertiesItem() .Build(); } private static object[] CalculationContextChildNodeObjects(MacroStabilityInwardsCalculationScenarioContext context) { MacroStabilityInwardsCalculationScenario macroStabilityInwardsCalculationScenario = context.WrappedData; return new object[] { macroStabilityInwardsCalculationScenario.Comments, new MacroStabilityInwardsInputContext(macroStabilityInwardsCalculationScenario.InputParameters, macroStabilityInwardsCalculationScenario, context.AvailableMacroStabilityInwardsSurfaceLines, context.AvailableStochasticSoilModels, context.FailureMechanism, context.AssessmentSection), new MacroStabilityInwardsOutputContext(macroStabilityInwardsCalculationScenario, context.FailureMechanism, context.AssessmentSection) }; } private static void CalculationContextOnNodeRemoved(MacroStabilityInwardsCalculationScenarioContext macroStabilityInwardsCalculationScenarioContext, object parentNodeData) { var calculationGroupContext = parentNodeData as MacroStabilityInwardsCalculationGroupContext; if (calculationGroupContext != null) { bool successfullyRemovedData = calculationGroupContext.WrappedData.Children.Remove(macroStabilityInwardsCalculationScenarioContext.WrappedData); if (successfullyRemovedData) { calculationGroupContext.NotifyObservers(); } } } private static void Validate(MacroStabilityInwardsCalculationScenarioContext context) { MacroStabilityInwardsCalculationService.Validate(context.WrappedData, GetNormativeAssessmentLevel(context.AssessmentSection, context.WrappedData)); } private void PerformCalculation(MacroStabilityInwardsCalculation calculation, MacroStabilityInwardsCalculationScenarioContext context) { ActivityProgressDialogRunner.Run( Gui.MainWindow, MacroStabilityInwardsCalculationActivityFactory.CreateCalculationActivity(calculation, context.AssessmentSection)); } #endregion #region MacroStabilityInwardsCalculationGroupContext TreeNodeInfo private static object[] CalculationGroupContextChildNodeObjects(MacroStabilityInwardsCalculationGroupContext nodeData) { var childNodeObjects = new List(); foreach (ICalculationBase item in nodeData.WrappedData.Children) { var calculation = item as MacroStabilityInwardsCalculationScenario; var group = item as CalculationGroup; if (calculation != null) { childNodeObjects.Add(new MacroStabilityInwardsCalculationScenarioContext(calculation, nodeData.WrappedData, nodeData.AvailableMacroStabilityInwardsSurfaceLines, nodeData.AvailableStochasticSoilModels, nodeData.FailureMechanism, nodeData.AssessmentSection)); } else if (group != null) { childNodeObjects.Add(new MacroStabilityInwardsCalculationGroupContext(group, nodeData.WrappedData, nodeData.AvailableMacroStabilityInwardsSurfaceLines, nodeData.AvailableStochasticSoilModels, nodeData.FailureMechanism, nodeData.AssessmentSection)); } else { childNodeObjects.Add(item); } } return childNodeObjects.ToArray(); } private ContextMenuStrip CalculationGroupContextContextMenuStrip(MacroStabilityInwardsCalculationGroupContext nodeData, object parentData, TreeViewControl treeViewControl) { CalculationGroup group = nodeData.WrappedData; var builder = new RingtoetsContextMenuBuilder(Gui.Get(nodeData, treeViewControl)); bool isNestedGroup = parentData is MacroStabilityInwardsCalculationGroupContext; StrictContextMenuItem generateCalculationsItem = CreateGenerateMacroStabilityInwardsCalculationsItem(nodeData); if (!isNestedGroup) { builder.AddOpenItem() .AddSeparator(); } builder.AddImportItem() .AddExportItem() .AddSeparator(); if (isNestedGroup) { builder.AddDuplicateCalculationItem(group, nodeData) .AddSeparator(); } else { builder.AddCustomItem(generateCalculationsItem) .AddSeparator(); } builder.AddCreateCalculationGroupItem(group) .AddCreateCalculationItem(nodeData, AddCalculationScenario) .AddSeparator(); if (isNestedGroup) { builder.AddRenameItem() .AddSeparator(); } builder.AddValidateAllCalculationsInGroupItem( nodeData, ValidateAll) .AddPerformAllCalculationsInGroupItem( group, nodeData, CalculateAll) .AddSeparator() .AddClearAllCalculationOutputInGroupItem(group); if (isNestedGroup) { builder.AddDeleteItem(); } else { builder.AddRemoveAllChildrenItem(); } return builder.AddSeparator() .AddCollapseAllItem() .AddExpandAllItem() .AddSeparator() .AddPropertiesItem() .Build(); } private void CalculateAll(CalculationGroup group, MacroStabilityInwardsCalculationGroupContext context) { ActivityProgressDialogRunner.Run( Gui.MainWindow, MacroStabilityInwardsCalculationActivityFactory.CreateCalculationActivities(group, context.AssessmentSection)); } private static void ValidateAll(MacroStabilityInwardsCalculationGroupContext context) { ValidateAll(context.WrappedData.GetCalculations().OfType(), context.AssessmentSection); } private static void AddCalculationScenario(MacroStabilityInwardsCalculationGroupContext nodeData) { var calculation = new MacroStabilityInwardsCalculationScenario { Name = NamingHelper.GetUniqueName(nodeData.WrappedData.Children, RingtoetsCommonDataResources.Calculation_DefaultName, c => c.Name) }; nodeData.WrappedData.Children.Add(calculation); nodeData.WrappedData.NotifyObservers(); } private StrictContextMenuItem CreateGenerateMacroStabilityInwardsCalculationsItem(MacroStabilityInwardsCalculationGroupContext nodeData) { bool surfaceLineAvailable = nodeData.AvailableMacroStabilityInwardsSurfaceLines.Any() && nodeData.AvailableStochasticSoilModels.Any(); string calculationGroupGenerateCalculationsToolTip = surfaceLineAvailable ? MacroStabilityInwardsFormsResources.MacroStabilityInwardsCalculationGroup_Generate_MacroStabilityInwardsCalculations_ToolTip : MacroStabilityInwardsFormsResources.MacroStabilityInwardsCalculationGroup_Generate_MacroStabilityInwardsCalculations_NoSurfaceLinesOrSoilModels_ToolTip; return new StrictContextMenuItem( RingtoetsCommonFormsResources.CalculationGroup_Generate_Scenarios, calculationGroupGenerateCalculationsToolTip, RingtoetsCommonFormsResources.GenerateScenariosIcon, (o, args) => ShowSurfaceLineSelectionDialog(nodeData)) { Enabled = surfaceLineAvailable }; } private void ShowSurfaceLineSelectionDialog(MacroStabilityInwardsCalculationGroupContext nodeData) { using (var view = new MacroStabilityInwardsSurfaceLineSelectionDialog(Gui.MainWindow, nodeData.AvailableMacroStabilityInwardsSurfaceLines)) { view.ShowDialog(); GenerateCalculations(nodeData.WrappedData, view.SelectedItems, nodeData.AvailableStochasticSoilModels); } nodeData.NotifyObservers(); } private static void GenerateCalculations(CalculationGroup target, IEnumerable surfaceLines, IEnumerable soilModels) { foreach (ICalculationBase group in MacroStabilityInwardsCalculationConfigurationHelper.GenerateCalculationItemsStructure(surfaceLines, soilModels)) { target.Children.Add(group); } } private static void CalculationGroupContextOnNodeRemoved(MacroStabilityInwardsCalculationGroupContext nodeData, object parentNodeData) { var parentGroupContext = (MacroStabilityInwardsCalculationGroupContext) parentNodeData; parentGroupContext.WrappedData.Children.Remove(nodeData.WrappedData); parentGroupContext.NotifyObservers(); } #endregion #region Ringtoets macro stability inwards surface line importer private static FileFilterGenerator SurfaceLineFileFilter { get { return new FileFilterGenerator( RingtoetsCommonFormsResources.DataTypeDisplayName_csv_file_filter_Extension, $"{RingtoetsCommonDataResources.SurfaceLineCollection_TypeDescriptor} {RingtoetsCommonFormsResources.DataTypeDisplayName_csv_file_filter_Description}"); } } private bool VerifySurfaceLineUpdates(MacroStabilityInwardsSurfaceLinesContext context, string query) { var changeHandler = new FailureMechanismCalculationChangeHandler(context.FailureMechanism, query, new DialogBasedInquiryHelper(Gui.MainWindow)); return !changeHandler.RequireConfirmation() || changeHandler.InquireConfirmation(); } #endregion } }