// 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 Core.Common.Base; using Ringtoets.Common.Data.UpdateDataStrategies; using Ringtoets.Common.IO.SurfaceLines; using Ringtoets.Common.Service; using Ringtoets.MacroStabilityInwards.Data; using Ringtoets.MacroStabilityInwards.Data.SoilProfile; using Ringtoets.MacroStabilityInwards.Forms; using Ringtoets.MacroStabilityInwards.Primitives; using Ringtoets.MacroStabilityInwards.Service; namespace Ringtoets.MacroStabilityInwards.Plugin.FileImporter { /// /// An for updating surface lines based on imported data. /// public class MacroStabilityInwardsSurfaceLineUpdateDataStrategy : UpdateDataStrategyBase, ISurfaceLineUpdateDataStrategy { /// /// Creates a new instance of . /// /// The failure mechanism in which the surface lines are updated. /// Thrown when is null. public MacroStabilityInwardsSurfaceLineUpdateDataStrategy(MacroStabilityInwardsFailureMechanism failureMechanism) : base(failureMechanism, failureMechanism?.SurfaceLines, new MacroStabilityInwardsSurfaceLineNameEqualityComparer()) {} public IEnumerable UpdateSurfaceLinesWithImportedData(IEnumerable surfaceLines, string sourceFilePath) { return UpdateTargetCollectionData(surfaceLines, sourceFilePath); } protected override IEnumerable RemoveObjectAndDependentData(MacroStabilityInwardsSurfaceLine removedSurfaceLine) { return MacroStabilityInwardsDataSynchronizationService.RemoveSurfaceLine(FailureMechanism, removedSurfaceLine); } /// /// Class for comparing by only the name. /// private class MacroStabilityInwardsSurfaceLineNameEqualityComparer : IEqualityComparer { public bool Equals(MacroStabilityInwardsSurfaceLine x, MacroStabilityInwardsSurfaceLine y) { return x.Name == y.Name; } public int GetHashCode(MacroStabilityInwardsSurfaceLine obj) { return obj.Name.GetHashCode(); } } #region Updating Data Functions protected override IEnumerable UpdateObjectAndDependentData(MacroStabilityInwardsSurfaceLine surfaceLineToUpdate, MacroStabilityInwardsSurfaceLine matchingSurfaceLine) { surfaceLineToUpdate.CopyProperties(matchingSurfaceLine); var affectedObjects = new List(); affectedObjects.AddRange(UpdateSurfaceLineDependentData(surfaceLineToUpdate)); affectedObjects.AddRange(UpdateStochasticSoilModel(surfaceLineToUpdate)); return affectedObjects; } private IEnumerable UpdateSurfaceLineDependentData(MacroStabilityInwardsSurfaceLine surfaceLine) { IEnumerable affectedCalculations = GetAffectedCalculationWithSurfaceLine(surfaceLine); var affectedObjects = new List(); foreach (MacroStabilityInwardsCalculation affectedCalculation in affectedCalculations) { affectedObjects.AddRange(RingtoetsCommonDataSynchronizationService.ClearCalculationOutput(affectedCalculation)); } return affectedObjects; } private IEnumerable UpdateStochasticSoilModel(MacroStabilityInwardsSurfaceLine updatedSurfaceLine) { IEnumerable calculationsToUpdate = GetAffectedCalculationWithSurfaceLine(updatedSurfaceLine); var affectedObjects = new List(); foreach (MacroStabilityInwardsCalculation calculation in calculationsToUpdate) { IEnumerable matchingSoilModels = GetAvailableStochasticSoilModels(updatedSurfaceLine); MacroStabilityInwardsInput calculationInput = calculation.InputParameters; MacroStabilityInwardsInputService.SetMatchingStochasticSoilModel(calculationInput, matchingSoilModels); affectedObjects.Add(calculationInput); } return affectedObjects; } private IEnumerable GetAffectedCalculationWithSurfaceLine(MacroStabilityInwardsSurfaceLine surfaceLine) { IEnumerable affectedCalculations = FailureMechanism.Calculations .Cast() .Where(calc => ReferenceEquals(calc.InputParameters.SurfaceLine, surfaceLine)); return affectedCalculations; } private IEnumerable GetAvailableStochasticSoilModels(MacroStabilityInwardsSurfaceLine surfaceLine) { return MacroStabilityInwardsCalculationConfigurationHelper.GetStochasticSoilModelsForSurfaceLine(surfaceLine, FailureMechanism.StochasticSoilModels); } #endregion } }