// Copyright (C) Stichting Deltares 2016. 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 Core.Common.Base.Geometry; using Ringtoets.Common.Data.Hydraulics; using Ringtoets.DuneErosion.Data; using Ringtoets.DuneErosion.IO; namespace Ringtoets.DuneErosion.Service { /// /// Service for synchronizing dune erosion data. /// public static class DuneErosionDataSynchronizationService { /// /// Sets based upon /// the . /// /// The to update. /// The hydraulic boundary location to use. /// The dune locations to use. /// Thrown when any parameter is null. public static void SetDuneLocations(DuneErosionFailureMechanism failureMechanism, HydraulicBoundaryLocation[] hydraulicBoundaryLocations, ReadDuneLocation[] duneLocations) { if (failureMechanism == null) { throw new ArgumentNullException("failureMechanism"); } if (hydraulicBoundaryLocations == null) { throw new ArgumentNullException("hydraulicBoundaryLocations"); } if (duneLocations == null) { throw new ArgumentNullException("duneLocations"); } failureMechanism.DuneLocations.Clear(); if (!hydraulicBoundaryLocations.Any() || !duneLocations.Any()) { return; } foreach (ReadDuneLocation duneLocation in duneLocations) { foreach (var hydraulicBoundaryLocation in hydraulicBoundaryLocations) { if (Math2D.AreEqualPoints(hydraulicBoundaryLocation.Location, duneLocation.Location)) { failureMechanism.DuneLocations.Add(new DuneLocation(hydraulicBoundaryLocation.Id, duneLocation.Name, duneLocation.Location, duneLocation.CoastalAreaId, duneLocation.Offset, duneLocation.Orientation, duneLocation.D50)); break; } } } } /// /// Clears the output of the dune locations within the collection. /// /// The locations for which the output needs to be cleared. /// All objects changed during the clear. /// Thrown when is null. public static IEnumerable ClearDuneLocationOutput(ObservableList locations) { if (locations == null) { throw new ArgumentNullException("locations"); } return locations.SelectMany(ClearDuneLocationOutput) .ToArray(); } private static IEnumerable ClearDuneLocationOutput(DuneLocation location) { if (location.Output != null) { location.Output = null; yield return location; } } } }