aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Tango.SharedUI
diff options
context:
space:
mode:
Diffstat (limited to 'Software/Visual_Studio/Tango.SharedUI')
-rw-r--r--Software/Visual_Studio/Tango.SharedUI/Helpers/DataGridHelper.cs67
-rw-r--r--Software/Visual_Studio/Tango.SharedUI/Tango.SharedUI.csproj3
2 files changed, 69 insertions, 1 deletions
diff --git a/Software/Visual_Studio/Tango.SharedUI/Helpers/DataGridHelper.cs b/Software/Visual_Studio/Tango.SharedUI/Helpers/DataGridHelper.cs
new file mode 100644
index 000000000..80c847a45
--- /dev/null
+++ b/Software/Visual_Studio/Tango.SharedUI/Helpers/DataGridHelper.cs
@@ -0,0 +1,67 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using System.Windows;
+using System.Windows.Controls;
+using System.Windows.Input;
+
+namespace Tango.SharedUI.Helpers
+{
+ public static class DataGridHelper
+ {
+ #region DoubleClickCommand
+
+ /// <summary>
+ /// Determines whether an element is DoubleClickCommand by the drag and drop service.
+ /// </summary>
+ public static readonly DependencyProperty DoubleClickCommandProperty =
+ DependencyProperty.RegisterAttached("DoubleClickCommand",
+ typeof(ICommand), typeof(DataGridHelper),
+ new FrameworkPropertyMetadata(null, DoubleClickCommandChanged));
+
+ /// <summary>
+ /// DoubleClickCommand changed.
+ /// </summary>
+ /// <param name="d">The d.</param>
+ /// <param name="e">The <see cref="DependencyPropertyChangedEventArgs"/> instance containing the event data.</param>
+ private static void DoubleClickCommandChanged(DependencyObject d, DependencyPropertyChangedEventArgs xx)
+ {
+ if (xx.NewValue != null)
+ {
+ var dataGrid = d as DataGrid;
+
+ dataGrid.MouseDoubleClick += (x, e) =>
+ {
+ if (dataGrid.SelectedItem != null && (e.OriginalSource as UIElement != null) && (e.OriginalSource as FrameworkElement).DataContext == dataGrid.SelectedItem)
+ {
+ (xx.NewValue as ICommand)?.Execute(dataGrid.SelectedItem);
+ }
+ };
+ }
+ }
+
+ /// <summary>
+ /// Sets the DoubleClickCommand attached property.
+ /// </summary>
+ /// <param name="dataGrid">The element.</param>
+ /// <param name="value">if set to <c>true</c> [value].</param>
+ public static void SetDoubleClickCommand(DataGrid dataGrid, ICommand value)
+ {
+ dataGrid.SetValue(DoubleClickCommandProperty, value);
+ }
+
+ /// <summary>
+ /// Gets the DoubleClickCommand attached property.
+ /// </summary>
+ /// <param name="dataGrid">The element.</param>
+ /// <returns></returns>
+ public static ICommand GetDoubleClickCommand(DataGrid dataGrid)
+ {
+ return (ICommand)dataGrid.GetValue(DoubleClickCommandProperty);
+ }
+
+ #endregion
+ }
+}
diff --git a/Software/Visual_Studio/Tango.SharedUI/Tango.SharedUI.csproj b/Software/Visual_Studio/Tango.SharedUI/Tango.SharedUI.csproj
index 4764d0eac..000a4e5d7 100644
--- a/Software/Visual_Studio/Tango.SharedUI/Tango.SharedUI.csproj
+++ b/Software/Visual_Studio/Tango.SharedUI/Tango.SharedUI.csproj
@@ -156,6 +156,7 @@
<Compile Include="Effects\DisplaySettingEffect.cs" />
<Compile Include="ExtensionMethods\FrameworkElementExtensions.cs" />
<Compile Include="Animations\GridLengthAnimation.cs" />
+ <Compile Include="Helpers\DataGridHelper.cs" />
<Compile Include="Helpers\PasswordHelper.cs" />
<Compile Include="Helpers\ResourceHelper.cs" />
<Compile Include="Helpers\UIHelper.cs" />
@@ -254,7 +255,7 @@
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
<ProjectExtensions>
<VisualStudio>
- <UserProperties BuildVersion_AssemblyInfoFilename="Properties\AssemblyInfo.cs" BuildVersion_UpdateAssemblyVersion="True" BuildVersion_BuildVersioningStyle="None.None.Increment.TimeStamp" BuildVersion_UseGlobalSettings="False" BuildVersion_StartDate="2000/1/1" />
+ <UserProperties BuildVersion_StartDate="2000/1/1" BuildVersion_UseGlobalSettings="False" BuildVersion_BuildVersioningStyle="None.None.Increment.TimeStamp" BuildVersion_UpdateAssemblyVersion="True" BuildVersion_AssemblyInfoFilename="Properties\AssemblyInfo.cs" />
</VisualStudio>
</ProjectExtensions>
</Project> \ No newline at end of file