/*************************************************************************************
Extended WPF Toolkit
Copyright (C) 2007-2013 Xceed Software Inc.
This program is provided to you under the terms of the Microsoft Public
License (Ms-PL) as published at http://wpftoolkit.codeplex.com/license
For more features, controls, and fast professional support,
pick up the Plus Edition at http://xceed.com/wpf_toolkit
Stay informed: follow @datagrid on Twitter or Like http://facebook.com/datagrids
***********************************************************************************/
using System.Windows.Controls.Primitives;
using System.Windows;
using System.Windows.Controls;
namespace Xceed.Wpf.AvalonDock.Controls
{
public class DropDownButton : ToggleButton
{
#region Constructors
public DropDownButton()
{
this.Unloaded += new RoutedEventHandler( DropDownButton_Unloaded );
}
#endregion
#region Properties
#region DropDownContextMenu
///
/// DropDownContextMenu Dependency Property
///
public static readonly DependencyProperty DropDownContextMenuProperty = DependencyProperty.Register( "DropDownContextMenu", typeof( ContextMenu ), typeof( DropDownButton ),
new FrameworkPropertyMetadata( ( ContextMenu )null, new PropertyChangedCallback( OnDropDownContextMenuChanged ) ) );
///
/// Gets or sets the DropDownContextMenu property. This dependency property
/// indicates drop down menu to show up when user click on an anchorable menu pin.
///
public ContextMenu DropDownContextMenu
{
get
{
return ( ContextMenu )GetValue( DropDownContextMenuProperty );
}
set
{
SetValue( DropDownContextMenuProperty, value );
}
}
///
/// Handles changes to the DropDownContextMenu property.
///
private static void OnDropDownContextMenuChanged( DependencyObject d, DependencyPropertyChangedEventArgs e )
{
( ( DropDownButton )d ).OnDropDownContextMenuChanged( e );
}
///
/// Provides derived classes an opportunity to handle changes to the DropDownContextMenu property.
///
protected virtual void OnDropDownContextMenuChanged( DependencyPropertyChangedEventArgs e )
{
var oldContextMenu = e.OldValue as ContextMenu;
if( oldContextMenu != null && IsChecked.GetValueOrDefault() )
oldContextMenu.Closed -= new RoutedEventHandler( OnContextMenuClosed );
}
#endregion
#region DropDownContextMenuDataContext
///
/// DropDownContextMenuDataContext Dependency Property
///
public static readonly DependencyProperty DropDownContextMenuDataContextProperty = DependencyProperty.Register( "DropDownContextMenuDataContext", typeof( object ), typeof( DropDownButton ),
new FrameworkPropertyMetadata( ( object )null ) );
///
/// Gets or sets the DropDownContextMenuDataContext property. This dependency property
/// indicates data context to set for drop down context menu.
///
public object DropDownContextMenuDataContext
{
get
{
return ( object )GetValue( DropDownContextMenuDataContextProperty );
}
set
{
SetValue( DropDownContextMenuDataContextProperty, value );
}
}
#endregion
#endregion
#region Overrides
protected override void OnClick()
{
if( DropDownContextMenu != null )
{
//IsChecked = true;
DropDownContextMenu.PlacementTarget = this;
DropDownContextMenu.Placement = PlacementMode.Bottom;
DropDownContextMenu.DataContext = DropDownContextMenuDataContext;
DropDownContextMenu.Closed += new RoutedEventHandler( OnContextMenuClosed );
DropDownContextMenu.IsOpen = true;
}
base.OnClick();
}
#endregion
#region Private Methods
private void OnContextMenuClosed( object sender, RoutedEventArgs e )
{
//Debug.Assert(IsChecked.GetValueOrDefault());
var ctxMenu = sender as ContextMenu;
ctxMenu.Closed -= new RoutedEventHandler( OnContextMenuClosed );
IsChecked = false;
}
private void DropDownButton_Unloaded( object sender, RoutedEventArgs e )
{
// When changing theme, Unloaded event is called, erasing the DropDownContextMenu.
// Prevent this on theme changes.
if( this.IsLoaded )
{
DropDownContextMenu = null;
}
}
#endregion
}
}