Please note, this blog entry is from a previous course. You might want to check out the current one.
Make one or more of your table views searchable. Check out UISearchDisplayController and UISearchBar.
Add a bar button to enable the search functionality in code and initialize it lazily:
@property (nonatomic, strong) IBOutlet UIBarButtonItem *searchButton; ... - (UIBarButtonItem *)searchButton { if (!_searchButton) { _searchButton = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemSearch target:self action:@selector(searchButtonPressed:)]; } return _searchButton; } - (void)viewDidLoad { ... self.navigationItem.rightBarButtonItem = self.searchButton; }
When the search button gets pressed, show the search bar and activate it (making it first responder), or hide it if the button gets pressed again:
- (IBAction)searchButtonPressed:(id)sender { if (self.tableView.tableHeaderView) { self.tableView.tableHeaderView = nil; } else { self.tableView.tableHeaderView = self.searchBar; if (self.searchPredicate) { self.searchPredicate = nil; [self setupFetchedResultsController]; } [self.searchBar becomeFirstResponder]; } }
The search bar is initialized lazily, defining the class also as delegate for the search functionality:
@interface FlickrPhotoTagTVC () <UISearchBarDelegate> ... @property (nonatomic, strong) UISearchBar *searchBar; ... - (UISearchBar *)searchBar { if (!_searchBar) { _searchBar = [[UISearchBar alloc] initWithFrame:self.navigationController.navigationBar.frame]; self.searchBar.delegate = self; } return _searchBar; }
When the text of the search bar changes, change the predicate for the fetched-results controller. When the search is “finished”, hide the search bar.
- (void)searchBar:(UISearchBar *)searchBar textDidChange:(NSString *)searchText { if ([searchText length]) { self.searchPredicate = [NSPredicate predicateWithFormat:@"name contains[cd] %@", searchText]; } else { self.searchPredicate = nil; } [self setupFetchedResultsController]; } - (void)searchBarTextDidEndEditing:(UISearchBar *)searchBar { self.tableView.tableHeaderView = nil; }
To let the fetched-results controller know, that it should actually “search” something use an additional property:
@property (nonatomic, strong) NSPredicate *searchPredicate; ... - (void)setupFetchedResultsController { ... request.predicate = self.searchPredicate; ... }
Follow those steps for the photo-table-view controller. The only difference here is that, this controller already has a predicate which needs to be combined with the search predicate:
- (void)setupFetchedResultsController { ... if (self.searchPredicate) { request.predicate = [NSCompoundPredicate andPredicateWithSubpredicates:@[request.predicate, self.searchPredicate]]; } ... }
For the recent-photos-table-view controller, just make the search-predicate property from the previous table public (so you do not have to redefine it again), and adjust the setup of the fetched-results controller.
The complete code is available on github.
data:image/s3,"s3://crabby-images/0463e/0463e68a5d77bbec630deb1cc37d4d49d1933e77" alt="Share on Facebook Facebook"
data:image/s3,"s3://crabby-images/93960/93960774b56bccf62f288efe326475d585239d8b" alt="Share on Twitter twitter"
data:image/s3,"s3://crabby-images/0c920/0c920341ab12cbcb5a3b1d2fb88f22374f2db577" alt="Share on Reddit reddit"
data:image/s3,"s3://crabby-images/d89b8/d89b80500f1626baf2ffa1e4369c261e01677d36" alt="Pin it with Pinterest pinterest"
data:image/s3,"s3://crabby-images/e9270/e92707689a9d88fc53f343370506e7f2aaedb7d1" alt="Share on Linkedin linkedin"
data:image/s3,"s3://crabby-images/f159f/f159fb333858fef1148f2a558ee7fa6a6881800a" alt="Share on tumblr tumblr"
data:image/s3,"s3://crabby-images/c7ab2/c7ab2f6c43fffe17aac7f185fd64ee95565487b9" alt="Share by email mail"
data:image/s3,"s3://crabby-images/6d85a/6d85a390df03e0c75624ac0579180ad35a62eeac" alt="Share on Facebook Facebook"
data:image/s3,"s3://crabby-images/e5f0c/e5f0cd4639d7b3d76b66c05981935f6c2bb06c71" alt="Share on Twitter twitter"
data:image/s3,"s3://crabby-images/40b77/40b7752481674a140035def4b6339fa4accc753f" alt="Share on Reddit reddit"
data:image/s3,"s3://crabby-images/1393f/1393f0291ffd80beac5e1f70b986671c6635d8b7" alt="Pin it with Pinterest pinterest"
data:image/s3,"s3://crabby-images/aa22d/aa22de91a0cd30772c623a5c7979ee81fe426013" alt="Share on Linkedin linkedin"
data:image/s3,"s3://crabby-images/5dc32/5dc32b39b30592e11870503bb4e8e715d50b21a0" alt="Share on tumblr tumblr"
data:image/s3,"s3://crabby-images/56655/56655b42634351b14f9d7507dacc4e33f64b90af" alt="Share by email mail"