summaryrefslogtreecommitdiff
path: root/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Issue2339.cs
diff options
context:
space:
mode:
authorJason Smith <jason.smith@xamarin.com>2016-03-22 13:02:25 -0700
committerJason Smith <jason.smith@xamarin.com>2016-03-22 16:13:41 -0700
commit17fdde66d94155fc62a034fa6658995bef6fd6e5 (patch)
treeb5e5073a2a7b15cdbe826faa5c763e270a505729 /Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Issue2339.cs
downloadxamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.tar.gz
xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.tar.bz2
xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.zip
Initial import
Diffstat (limited to 'Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Issue2339.cs')
-rw-r--r--Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Issue2339.cs66
1 files changed, 66 insertions, 0 deletions
diff --git a/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Issue2339.cs b/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Issue2339.cs
new file mode 100644
index 00000000..aa958607
--- /dev/null
+++ b/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Issue2339.cs
@@ -0,0 +1,66 @@
+using System.Diagnostics;
+using System.Threading.Tasks;
+using Xamarin.Forms.CustomAttributes;
+
+namespace Xamarin.Forms.Controls
+{
+ [Preserve (AllMembers=true)]
+ [Issue (IssueTracker.Github, 2339, "Picker not shown when .Focus() is called", PlatformAffected.WinPhone)]
+ public class Issue2339 : ContentPage
+ {
+ public Issue2339 ()
+ {
+ var picker = new Picker { Items = {"One", "Two", "Three"} };
+ var pickerBtn = new Button {
+ Text = "Click me to call .Focus on Picker"
+ };
+
+ pickerBtn.Clicked += (sender, args) => {
+ picker.Focus ();
+ };
+
+ var pickerBtn2 = new Button {
+ Text = "Click me to call .Unfocus on Picker"
+ };
+
+ pickerBtn2.Clicked += (sender, args) => {
+ picker.Unfocus ();
+ };
+
+ var pickerBtn3 = new Button {
+ Text = "Click me to .Focus () picker, wait 2 seconds, and .Unfocus () picker",
+ Command = new Command (async () => {
+ picker.Focus ();
+ await Task.Delay (2000);
+ picker.Unfocus ();
+ })
+ };
+
+ var focusFiredCount = 0;
+ var unfocusFiredCount = 0;
+
+ var focusFiredLabel = new Label { Text = "Picker Focused: " + focusFiredCount };
+ var unfocusedFiredLabel = new Label { Text = "Picker UnFocused: " + unfocusFiredCount };
+
+ picker.Focused += (s, e) => {
+ focusFiredCount++;
+ focusFiredLabel.Text = "Picker Focused: " + focusFiredCount;
+ };
+ picker.Unfocused += (s, e) => {
+ unfocusFiredCount++;
+ unfocusedFiredLabel.Text = "Picker UnFocused: " + unfocusFiredCount;
+ };
+
+ Content = new StackLayout {
+ Children = {
+ focusFiredLabel,
+ unfocusedFiredLabel,
+ pickerBtn,
+ pickerBtn2,
+ pickerBtn3,
+ picker
+ }
+ };
+ }
+ }
+}