From 2a300b070c7cbcdb36fbbebb371fd092dc7c020b Mon Sep 17 00:00:00 2001 From: Vitaly Knyazev Date: Tue, 14 Mar 2017 16:22:21 +0000 Subject: [PATCH] =?UTF-8?q?Bug=2051536,=20initial=20iOS=20cell=20layout=20?= =?UTF-8?q?is=20incorrect=20when=20cell=20has=20context=20actions=20?= =?UTF-8?q?=E2=80=A6=20(#787)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Bug 51536, initial height is incorrect when cell has context actions or ListView is in recycle mode * Improved fix for iOS uneven height cell layout * Fixed indentation and added test case for issue 44525 * Fixed indentation for test case * Added 1px room, this will fix Bugzilla31330 test, renamed test case to 51536 * Updated shared project file --- .../Bugzilla51536.cs | 81 +++++++++++++++++++ ...rin.Forms.Controls.Issues.Shared.projitems | 2 + .../ContextActionCell.cs | 3 +- 3 files changed, 85 insertions(+), 1 deletion(-) create mode 100644 Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Bugzilla51536.cs diff --git a/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Bugzilla51536.cs b/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Bugzilla51536.cs new file mode 100644 index 00000000000..05149128735 --- /dev/null +++ b/Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared/Bugzilla51536.cs @@ -0,0 +1,81 @@ +using System.Linq; +using Xamarin.Forms.CustomAttributes; +using Xamarin.Forms.Internals; + +namespace Xamarin.Forms.Controls.Issues +{ + [Preserve(AllMembers = true)] + [Issue(IssueTracker.Bugzilla, 51536, "[iOS] Xamarin.Forms ListView Row Height Does Not Adapt")] + public class Bugzilla51536 : TestContentPage + { + protected override void Init() + { + const string InstructionsLong = "On iOS, all the list items below will have different height defined by this text, the text " + + "should be wrapped and take all cell space. If this text is not wrapped and there is a lot of " + + "whitespace in the cell then this test has failed. This error was happening to ListView with RecycleElement mode " + + "or when cell has context actions."; + + const string InstructionsShort = "On iOS, all the list items below will have different height defined by this text."; + + var listItems = Enumerable.Range(1, 100).Select(i => new ItemViewModel + { + Name = "Item" + i, + Description = i % 2 == 0 ? (InstructionsLong + i) : (InstructionsShort + i) + }).ToArray(); + + var listView = new ListView(ListViewCachingStrategy.RecycleElement) + { + ItemTemplate = new DataTemplate(typeof(ItemViewCell)), + HasUnevenRows = true, + ItemsSource = listItems + }; + + Content = listView; + } + } + + [Preserve(AllMembers = true)] + public sealed class ItemViewModel + { + public string Name { get; set; } + public string Description { get; set; } + } + + [Preserve(AllMembers = true)] + public sealed class ItemViewCell : ViewCell + { + public Label Label1 { get; set; } + public Label Label2 { get; set; } + + public ItemViewCell() + { + var stackLayout = new StackLayout + { + Orientation = StackOrientation.Vertical, + HorizontalOptions = LayoutOptions.StartAndExpand, + VerticalOptions = LayoutOptions.StartAndExpand + }; + + Label1 = new Label(); + Label2 = new Label { LineBreakMode = LineBreakMode.WordWrap }; + + stackLayout.Children.Add(Label1); + stackLayout.Children.Add(Label2); + + View = stackLayout; + } + + protected override void OnBindingContextChanged() + { + base.OnBindingContextChanged(); + + var item = BindingContext as ItemViewModel; + + if (item != null) + { + Label1.Text = item.Name; + Label2.Text = item.Description; + } + } + } +} \ 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 77b8f4e5cbc..b2f7949206f 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 @@ -142,6 +142,8 @@ + + diff --git a/Xamarin.Forms.Platform.iOS/ContextActionCell.cs b/Xamarin.Forms.Platform.iOS/ContextActionCell.cs index 2e5925c7815..cac9e9efbd1 100644 --- a/Xamarin.Forms.Platform.iOS/ContextActionCell.cs +++ b/Xamarin.Forms.Platform.iOS/ContextActionCell.cs @@ -87,7 +87,8 @@ public override void LayoutSubviews() { base.LayoutSubviews(); - if (_scroller == null || (_scroller != null && _scroller.Frame.Width == ContentView.Bounds.Width)) + // Leave room for 1px of play because the border is 1 or .5px and must be accounted for. + if (_scroller == null || (_scroller.Frame.Width == ContentView.Bounds.Width && Math.Abs(_scroller.Frame.Height - ContentView.Bounds.Height) < 1)) return; Update(_tableView, _cell, ContentCell);