From 080f1697e97e13461ec6df4d31c8924d01257a1b Mon Sep 17 00:00:00 2001 From: Roy Ben Shabat Date: Tue, 9 Apr 2019 01:47:48 +0300 Subject: MERGE --- .../CodeCompletion/OverloadViewer.cs | 101 +++++++++++++++++++++ 1 file changed, 101 insertions(+) create mode 100644 Software/Visual_Studio/Scripting/Tango.Scripting.Editors/CodeCompletion/OverloadViewer.cs (limited to 'Software/Visual_Studio/Scripting/Tango.Scripting.Editors/CodeCompletion/OverloadViewer.cs') diff --git a/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/CodeCompletion/OverloadViewer.cs b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/CodeCompletion/OverloadViewer.cs new file mode 100644 index 000000000..f70229a8d --- /dev/null +++ b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/CodeCompletion/OverloadViewer.cs @@ -0,0 +1,101 @@ +// Copyright (c) AlphaSierraPapa for the SharpDevelop Team (for details please see \doc\copyright.txt) +// This code is distributed under the GNU LGPL (for details please see \doc\license.txt) + +using System; +using System.Collections.ObjectModel; +using System.ComponentModel; +using System.Globalization; +using System.Windows; +using System.Windows.Controls; +using System.Windows.Data; + +namespace Tango.Scripting.Editors.CodeCompletion +{ + /// + /// Represents a text between "Up" and "Down" buttons. + /// + public class OverloadViewer : Control + { + static OverloadViewer() + { + DefaultStyleKeyProperty.OverrideMetadata(typeof(OverloadViewer), + new FrameworkPropertyMetadata(typeof(OverloadViewer))); + } + + /// + /// The text property. + /// + public static readonly DependencyProperty TextProperty = + DependencyProperty.Register("Text", typeof(string), typeof(OverloadViewer)); + + /// + /// Gets/Sets the text between the Up and Down buttons. + /// + public string Text { + get { return (string)GetValue(TextProperty); } + set { SetValue(TextProperty, value); } + } + + /// + public override void OnApplyTemplate() + { + base.OnApplyTemplate(); + + Button upButton = (Button)this.Template.FindName("PART_UP", this); + upButton.Click += (sender, e) => { + e.Handled = true; + ChangeIndex(-1); + }; + + Button downButton = (Button)this.Template.FindName("PART_DOWN", this); + downButton.Click += (sender, e) => { + e.Handled = true; + ChangeIndex(+1); + }; + } + + /// + /// The ItemProvider property. + /// + public static readonly DependencyProperty ProviderProperty = + DependencyProperty.Register("Provider", typeof(IOverloadProvider), typeof(OverloadViewer)); + + /// + /// Gets/Sets the item provider. + /// + public IOverloadProvider Provider { + get { return (IOverloadProvider)GetValue(ProviderProperty); } + set { SetValue(ProviderProperty, value); } + } + + /// + /// Changes the selected index. + /// + /// The relative index change - usual values are +1 or -1. + public void ChangeIndex(int relativeIndexChange) + { + IOverloadProvider p = this.Provider; + if (p != null) { + int newIndex = p.SelectedIndex + relativeIndexChange; + if (newIndex < 0) + newIndex = p.Count - 1; + if (newIndex >= p.Count) + newIndex = 0; + p.SelectedIndex = newIndex; + } + } + } + + sealed class CollapseIfSingleOverloadConverter : IValueConverter + { + public object Convert(object value, Type targetType, object parameter, CultureInfo culture) + { + return ((int)value < 2) ? Visibility.Collapsed : Visibility.Visible; + } + + public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture) + { + throw new NotImplementedException(); + } + } +} -- cgit v1.3.1