aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Scripting/Tango.Scripting.IDE/Converters
diff options
context:
space:
mode:
authorShlomo Hecht <shlomo@twine-s.com>2019-04-08 15:09:50 +0300
committerShlomo Hecht <shlomo@twine-s.com>2019-04-08 15:09:50 +0300
commit46cdc21087d55e3bc5ca1d04b183f47bcfb3924f (patch)
tree175525aa0fe7e5831775fd9bb9f404d4dcf78b35 /Software/Visual_Studio/Scripting/Tango.Scripting.IDE/Converters
parentc36ea9eb28cd27cbf68187a0ce77536ca3442129 (diff)
parent33de6bbb3668c5d1edf9c28ee337058a29331443 (diff)
downloadTango-46cdc21087d55e3bc5ca1d04b183f47bcfb3924f.tar.gz
Tango-46cdc21087d55e3bc5ca1d04b183f47bcfb3924f.zip
Merge branch 'master' of https://twinetfs.visualstudio.com/Tango/_git/Tango
Diffstat (limited to 'Software/Visual_Studio/Scripting/Tango.Scripting.IDE/Converters')
-rw-r--r--Software/Visual_Studio/Scripting/Tango.Scripting.IDE/Converters/LeftMarginMultiplierConverter.cs54
1 files changed, 54 insertions, 0 deletions
diff --git a/Software/Visual_Studio/Scripting/Tango.Scripting.IDE/Converters/LeftMarginMultiplierConverter.cs b/Software/Visual_Studio/Scripting/Tango.Scripting.IDE/Converters/LeftMarginMultiplierConverter.cs
new file mode 100644
index 000000000..2acefc09c
--- /dev/null
+++ b/Software/Visual_Studio/Scripting/Tango.Scripting.IDE/Converters/LeftMarginMultiplierConverter.cs
@@ -0,0 +1,54 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using System.Globalization;
+using System.Windows;
+using System.Windows.Controls;
+using System.Windows.Data;
+using System.Windows.Media;
+
+namespace Tango.Scripting.IDE.Converters
+{
+ public static class TreeViewItemExtensions
+ {
+ public static int GetDepth(this TreeViewItem item)
+ {
+ TreeViewItem parent;
+ while ((parent = GetParent(item)) != null)
+ {
+ return GetDepth(parent) + 1;
+ }
+ return 0;
+ }
+
+ private static TreeViewItem GetParent(TreeViewItem item)
+ {
+ var parent = VisualTreeHelper.GetParent(item);
+ while (!(parent is TreeViewItem || parent is TreeView))
+ {
+ parent = VisualTreeHelper.GetParent(parent);
+ }
+ return parent as TreeViewItem;
+ }
+ }
+ public class LeftMarginMultiplierConverter : IValueConverter
+ {
+ public double Length { get; set; }
+
+ public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
+ {
+ var item = value as TreeViewItem;
+ if (item == null)
+ return new Thickness(0);
+
+ return new Thickness(Length * item.GetDepth(), 0, 0, 0);
+ }
+
+ public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
+ {
+ throw new System.NotImplementedException();
+ }
+ }
+}