Reputation: 17832
This must be trivial, but I can't find how you're supposed to dismiss a UISearchController programmatically?
Note that it's the new UISearchController (introduced in 2014 with iOS 8), not the UISearchDisplayController.
So far here's what I've got
// Dismiss the search tableview
searchController.dismissViewControllerAnimated()
// Clear the Search bar text
searchController.active = false
But I still have the cancel button and can't get rid of it.
Upvotes: 76
Views: 35673
Reputation: 17832
OK so after more testing, turns out you just have to set:
searchController.active = false
// or swift 4+
searchController.isActive = false
This is the first thing I tried but I called it in one of the UISearchControllerDelegate methods which didn't work (probably should have called it with dispatch_async (halbano's answer seems to confirm that)).
Anyway, since I couldn't find that answer online, I'm answering my own question, I hope that it'll help someone.
Upvotes: 186
Reputation: 29
I had this problem using the search and interactionController, solved after just include the line: self.dismissViewControllerAnimated(false, completion: nil)
Open the interaction and clear the search without changes in the delegate.
Upvotes: 2
Reputation: 1305
I was presenting the mine embed on a navigation bar. The code that works for me was:
- (void)searchBarCancelButtonClicked:(UISearchBar *)searchBar{
dispatch_async(dispatch_get_main_queue(), ^{
[self.searchController setActive:NO];
self.navigationController.navigationBar.topItem.title = @"MYTITLE".uppercaseString;
self.navigationItem.titleView = nil;
});
}
Hope it helps someone.
Upvotes: 11
Reputation: 406
Did you have this problem when you try to dismiss search controller after segueing to another view? I have encountered this problem too. I think you might want to use
self.definesPresentationContext = true
in the view controller that presents the UISearchController as per this post UISearchController not dismissed when View is pushed. It works for me.
Upvotes: 25