summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul DiPietro <pauldipietro@users.noreply.github.com>2016-10-11 11:56:20 -0500
committerSamantha Houts <samantha@teamredwall.com>2016-10-11 09:56:20 -0700
commitd5f4aeb4745e0b1e171275b7311b9e7a8d98d02d (patch)
tree9bd87fd73d90540f80dae84ab30b2d9bd8012a4e
parent1612cfab7934391efc9b33c91dc413dabfe53fa5 (diff)
downloadxamarin-forms-d5f4aeb4745e0b1e171275b7311b9e7a8d98d02d.tar.gz
xamarin-forms-d5f4aeb4745e0b1e171275b7311b9e7a8d98d02d.tar.bz2
xamarin-forms-d5f4aeb4745e0b1e171275b7311b9e7a8d98d02d.zip
[WinRT] Fix MDP and TabbedPage Appearing/Disappearing (#387)
-rw-r--r--Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Bugzilla40408.cs94
-rw-r--r--Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Xamarin.Forms.Controls.Issues.Shared.projitems1
-rw-r--r--Xamarin.Forms.Platform.WinRT.Phone/TabbedPageRenderer.cs2
-rw-r--r--Xamarin.Forms.Platform.WinRT.Tablet/TabbedPageRenderer.cs2
-rw-r--r--Xamarin.Forms.Platform.WinRT/MasterDetailPageRenderer.cs1
5 files changed, 100 insertions, 0 deletions
diff --git a/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Bugzilla40408.cs b/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Bugzilla40408.cs
new file mode 100644
index 00000000..0fe2efc1
--- /dev/null
+++ b/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Bugzilla40408.cs
@@ -0,0 +1,94 @@
+using Xamarin.Forms.CustomAttributes;
+using Xamarin.Forms.Internals;
+using System;
+
+#if UITEST
+using Xamarin.UITest;
+using NUnit.Framework;
+#endif
+
+namespace Xamarin.Forms.Controls.Issues
+{
+ [Preserve(AllMembers = true)]
+ [Issue(IssueTracker.Bugzilla, 40408, "MasterDetailPage and TabbedPage only firing Appearing once", PlatformAffected.WinRT)]
+ public class Bugzilla40408 : TestNavigationPage
+ {
+ protected override void Init()
+ {
+ BarBackgroundColor = Color.Red;
+
+ var contentPage2 = new ContentPage();
+ contentPage2.Title = "Page 2";
+ contentPage2.BackgroundColor = Color.Green;
+
+ contentPage2.Appearing += ContentPage2_Appearing;
+ contentPage2.Disappearing += ContentPage2_Disappearing;
+
+ var tabbedPage1 = new TabbedPage();
+ tabbedPage1.Appearing += TabbedPage1_Appearing;
+ tabbedPage1.Disappearing += TabbedPage1_Disappearing;
+
+ var contentPage3 = new ContentPage() { Title = "Page 3" };
+ contentPage3.BackgroundColor = Color.Pink;
+ tabbedPage1.Children.Add(contentPage3);
+
+ var masterDetailPage1 = new MasterDetailPage();
+ masterDetailPage1.Title = "Page 3";
+ var master1 = new ContentPage();
+ master1.BackgroundColor = Color.Yellow;
+ master1.Title = "Master 1";
+ var detail1 = new ContentPage();
+ detail1.Title = "Detail 1";
+ detail1.BackgroundColor = Color.Purple;
+ masterDetailPage1.Master = master1;
+ masterDetailPage1.Detail = detail1;
+ masterDetailPage1.BackgroundColor = Color.Yellow;
+
+ masterDetailPage1.Appearing += MasterDetailPage1_Appearing;
+ masterDetailPage1.Disappearing += MasterDetailPage1_Disappearing;
+
+ var contentPage1 = new ContentPage();
+ SetHasBackButton(contentPage1, true);
+ contentPage1.BackgroundColor = Color.Blue;
+ contentPage1.Title = "Page 1";
+ var stack = new StackLayout();
+ contentPage1.Content = stack;
+
+ stack.Children.Add(new Button() { Text = "View Content", Command = new Command(() => PushAsync(contentPage2)) });
+ stack.Children.Add(new Button() { Text = "View Master Detail", Command = new Command(() => PushAsync(masterDetailPage1)) });
+ stack.Children.Add(new Button() { Text = "View Tabbed Page", Command = new Command(() => PushAsync(tabbedPage1)) });
+
+ PushAsync(contentPage1);
+ }
+
+ void ContentPage2_Disappearing(object sender, EventArgs e)
+ {
+ DisplayAlert("Disappearing", "ContentPage", "OK");
+ }
+
+ void TabbedPage1_Disappearing(object sender, EventArgs e)
+ {
+ DisplayAlert("Disappearing", "TabbedPage", "OK");
+ }
+
+ void MasterDetailPage1_Disappearing(object sender, EventArgs e)
+ {
+ DisplayAlert("Disappearing", "MasterDetailPage", "OK");
+ }
+
+ void TabbedPage1_Appearing(object sender, EventArgs e)
+ {
+ DisplayAlert("Appearing", "TabbedPage", "OK");
+ }
+
+ void ContentPage2_Appearing(object sender, EventArgs e)
+ {
+ DisplayAlert("Appearing", "ContentPage", "OK");
+ }
+
+ void MasterDetailPage1_Appearing(object sender, EventArgs e)
+ {
+ DisplayAlert("Appearing", "MasterDetailPage", "OK");
+ }
+ }
+} \ No newline at end of file
diff --git a/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Xamarin.Forms.Controls.Issues.Shared.projitems b/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Xamarin.Forms.Controls.Issues.Shared.projitems
index 51171be2..a1dd9b44 100644
--- a/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Xamarin.Forms.Controls.Issues.Shared.projitems
+++ b/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Xamarin.Forms.Controls.Issues.Shared.projitems
@@ -106,6 +106,7 @@
<Compile Include="$(MSBuildThisFileDirectory)Bugzilla40185.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Bugzilla40333.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Bugzilla31806.cs" />
+ <Compile Include="$(MSBuildThisFileDirectory)Bugzilla40408.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Bugzilla40858.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Bugzilla40824.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Bugzilla40911.cs" />
diff --git a/Xamarin.Forms.Platform.WinRT.Phone/TabbedPageRenderer.cs b/Xamarin.Forms.Platform.WinRT.Phone/TabbedPageRenderer.cs
index b6731ce9..25c4d9ed 100644
--- a/Xamarin.Forms.Platform.WinRT.Phone/TabbedPageRenderer.cs
+++ b/Xamarin.Forms.Platform.WinRT.Phone/TabbedPageRenderer.cs
@@ -146,6 +146,8 @@ namespace Xamarin.Forms.Platform.WinRT
return;
_disposed = true;
+
+ PageController?.SendDisappearing();
SetElement(null);
Tracker = null;
}
diff --git a/Xamarin.Forms.Platform.WinRT.Tablet/TabbedPageRenderer.cs b/Xamarin.Forms.Platform.WinRT.Tablet/TabbedPageRenderer.cs
index 7d3b1a8c..2cfc2411 100644
--- a/Xamarin.Forms.Platform.WinRT.Tablet/TabbedPageRenderer.cs
+++ b/Xamarin.Forms.Platform.WinRT.Tablet/TabbedPageRenderer.cs
@@ -155,6 +155,8 @@ namespace Xamarin.Forms.Platform.WinRT
return;
_disposed = true;
+
+ PageController?.SendDisappearing();
SetElement(null);
Tracker = null;
}
diff --git a/Xamarin.Forms.Platform.WinRT/MasterDetailPageRenderer.cs b/Xamarin.Forms.Platform.WinRT/MasterDetailPageRenderer.cs
index abc614bd..414870cd 100644
--- a/Xamarin.Forms.Platform.WinRT/MasterDetailPageRenderer.cs
+++ b/Xamarin.Forms.Platform.WinRT/MasterDetailPageRenderer.cs
@@ -143,6 +143,7 @@ namespace Xamarin.Forms.Platform.WinRT
_disposed = true;
+ PageController?.SendDisappearing();
SetElement(null);
}