// 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 Lesser 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 Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser 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 Core.Common.Gui; using Core.Common.Gui.ContextMenu; using Core.Common.Gui.Forms.ViewHost; using Core.Components.Gis.Forms; using Core.Plugins.Map.Properties; namespace Core.Plugins.Map.Legend { /// /// This class controls the actions which are related to controlling visibility and updating contents of a . /// public class MapLegendController : IDisposable { private readonly IViewController viewController; private readonly IContextMenuBuilderProvider contextMenuBuilderProvider; /// /// Fired when the map legend has been opened. /// public EventHandler OnOpenLegend; private MapLegendView legendView; /// /// Creates a new instance of . /// /// The to invoke actions upon. /// The to create context menus. /// Thrown when /// or is null. public MapLegendController(IViewController viewController, IContextMenuBuilderProvider contextMenuBuilderProvider) { if (viewController == null) { throw new ArgumentNullException(nameof(viewController), $@"Cannot create a {typeof(MapLegendController).Name} when the view controller is null."); } if (contextMenuBuilderProvider == null) { throw new ArgumentNullException(nameof(contextMenuBuilderProvider), $@"Cannot create a {typeof(MapLegendController).Name} when the context menu builder provider is null."); } this.viewController = viewController; this.contextMenuBuilderProvider = contextMenuBuilderProvider; } /// /// Gets a value indicating whether the is visible. /// public bool IsMapLegendViewOpen { get { return legendView != null && viewController.ViewHost.ToolViews.Contains(legendView); } } /// /// Toggles the visibility of the . /// public void ToggleView() { if (IsMapLegendViewOpen) { CloseLegendView(); } else { OpenLegendView(); } } /// /// Updates the data for the if it is open. /// /// The being shown, for which /// the legend view should to show its contents. If null, the legend view /// will be cleared. public void Update(IMapControl mapControl) { if (IsMapLegendViewOpen) { legendView.MapControl = mapControl; } } public void Dispose() { Dispose(true); GC.SuppressFinalize(this); } protected virtual void Dispose(bool disposing) { if (disposing) { CloseLegendView(); } } /// /// Opens the . /// private void OpenLegendView() { legendView = new MapLegendView(contextMenuBuilderProvider); viewController.ViewHost.AddToolView(legendView, ToolViewLocation.Left); viewController.ViewHost.SetImage(legendView, Resources.MapIcon); OnOpenLegend?.Invoke(this, EventArgs.Empty); } /// /// Closes the . /// private void CloseLegendView() { viewController.ViewHost.Remove(legendView); legendView.Dispose(); legendView = null; } } }