Created
February 22, 2015 04:44
Move toolbar items with priority = 0 to LeftBarButtonItems on iOS with Xamarin Forms. Originally written by Murally at http://forums.xamarin.com/discussion/21004/navigation-bar-left-toolbar-button
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
[assembly: ExportRenderer(typeof(ContentPage), typeof(ExtendedPageRenderer))] | |
public class ExtendedPageRenderer : PageRenderer | |
{ | |
public override void ViewWillAppear(bool animated) | |
{ | |
base.ViewWillAppear(animated); | |
var contentPage = this.Element as ContentPage; | |
if (contentPage == null || NavigationController == null) | |
{ | |
return; | |
} | |
var itemsInfo = contentPage.ToolbarItems; | |
var navigationItem = this.NavigationController.TopViewController.NavigationItem; | |
var leftNativeButtons = (navigationItem.LeftBarButtonItems ?? new UIBarButtonItem[] { }).ToList(); | |
var rightNativeButtons = (navigationItem.RightBarButtonItems ?? new UIBarButtonItem[] { }).ToList(); | |
rightNativeButtons.ForEach(nativeItem => | |
{ | |
// [Hack] Get Xamarin private field "item" | |
var field = nativeItem.GetType().GetField("item", BindingFlags.NonPublic | BindingFlags.Instance); | |
if (field == null) | |
{ | |
return; | |
} | |
var info = field.GetValue(nativeItem) as ToolbarItem; | |
if (info != null && info.Priority != 0) | |
{ | |
return; | |
} | |
rightNativeButtons.Remove(nativeItem); | |
leftNativeButtons.Add(nativeItem); | |
}); | |
navigationItem.RightBarButtonItems = rightNativeButtons.ToArray(); | |
navigationItem.LeftBarButtonItems = leftNativeButtons.ToArray(); | |
} | |
} |
I modified the code to build new collections instead of modifying the existing collections to avoid the Collection Modified exceptions as mentioned by @KeesAlderliesten.
To prevent the Collection Modified Exception, simply do a ToList
before the ForEach
, like so:
rightNativeButtons.ToList().ForEach(nativeItem =>
This works because now you're iterating over a copy of the list.
Just started using XF-2.2.0* and noticed the private field has been renamed to _item.
So, on line 24 rename "item" to "_item". Then it's working fine again.
And by the way, thanks for this peace of code! It's the best way to move the toolbaritem so far!
How about this such as render for Android ? is possible to Arranged toolbar item to Left even order as secondary ?
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
With two buttons (one left and one right) I get an 'Collection modified' exception after the Remove(nativeItem).
I got this working by creating a new List for the right items:
Then before the returns I added:
and removed
and in the end changed this line
This prevents the exception...