/* * Copyright 2010-present Facebook. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #import #import #import "FBCacheDescriptor.h" #import "FBGraphObjectPickerViewController.h" #import "FBGraphPlace.h" @protocol FBPlacePickerDelegate; /*! @class FBPlacePickerViewController @abstract The `FBPlacePickerViewController` class creates a controller object that manages the user interface for displaying and selecting nearby places. @discussion When the `FBPlacePickerViewController` view loads it creates a `UITableView` object where the places near a given location will be displayed. You can access this view through the `tableView` property. The place data can be pre-fetched and cached prior to using the view controller. The cache is setup using an object that can trigger the data fetch. Any place data requests will first check the cache and use that data. If the place picker is being displayed cached data will initially be shown before a fresh copy is retrieved. The `delegate` property may be set to an object that conforms to the protocol. The `delegate` object will receive updates related to place selection and data changes. The delegate can also be used to filter the places to display in the picker. */ @interface FBPlacePickerViewController : FBGraphObjectPickerViewController /*! @abstract The coordinates to use for place discovery. */ @property (nonatomic) CLLocationCoordinate2D locationCoordinate; /*! @abstract The radius to use for place discovery. */ @property (nonatomic) NSInteger radiusInMeters; /*! @abstract The maximum number of places to fetch. */ @property (nonatomic) NSInteger resultsLimit; /*! @abstract The search words used to narrow down the results returned. */ @property (nonatomic, copy) NSString *searchText; /*! @abstract The place that is currently selected in the view. This is nil if nothing is selected. */ @property (nonatomic, retain, readonly) id selection; /*! @abstract Configures the properties used in the caching data queries. @discussion Cache descriptors are used to fetch and cache the data used by the view controller. If the view controller finds a cached copy of the data, it will first display the cached content then fetch a fresh copy from the server. @param cacheDescriptor The containing the cache query properties. */ - (void)configureUsingCachedDescriptor:(FBCacheDescriptor *)cacheDescriptor; /*! @method @abstract Creates a cache descriptor with additional fields and a profile ID for use with the `FBPlacePickerViewController` object. @discussion An `FBCacheDescriptor` object may be used to pre-fetch data before it is used by the view controller. It may also be used to configure the `FBPlacePickerViewController` object. @param locationCoordinate The coordinates to use for place discovery. @param radiusInMeters The radius to use for place discovery. @param searchText The search words used to narrow down the results returned. @param resultsLimit The maximum number of places to fetch. @param fieldsForRequest Addtional fields to fetch when making the Graph API call to get place data. */ + (FBCacheDescriptor *)cacheDescriptorWithLocationCoordinate:(CLLocationCoordinate2D)locationCoordinate radiusInMeters:(NSInteger)radiusInMeters searchText:(NSString *)searchText resultsLimit:(NSInteger)resultsLimit fieldsForRequest:(NSSet *)fieldsForRequest; @end /*! @protocol @abstract The `FBPlacePickerDelegate` protocol defines the methods used to receive event notifications and allow for deeper control of the view. The methods of correspond to . If a pair of corresponding methods are implemented, the method is called first. */ @protocol FBPlacePickerDelegate @optional /*! @abstract Tells the delegate that data has been loaded. @discussion The object's `tableView` property is automatically reloaded when this happens. However, if another table view, for example the `UISearchBar` is showing data, then it may also need to be reloaded. @param placePicker The place picker view controller whose data changed. */ - (void)placePickerViewControllerDataDidChange:(FBPlacePickerViewController *)placePicker; /*! @abstract Tells the delegate that the selection has changed. @param placePicker The place picker view controller whose selection changed. */ - (void)placePickerViewControllerSelectionDidChange:(FBPlacePickerViewController *)placePicker; /*! @abstract Asks the delegate whether to include a place in the list. @discussion This can be used to implement a search bar that filters the places list. If -[ graphObjectPickerViewController:shouldIncludeGraphObject:] is implemented and returns NO, this method is not called. @param placePicker The place picker view controller that is requesting this information. @param place An object representing the place. */ - (BOOL)placePickerViewController:(FBPlacePickerViewController *)placePicker shouldIncludePlace:(id)place; /*! @abstract Called if there is a communication error. @param placePicker The place picker view controller that encountered the error. @param error An error object containing details of the error. */ - (void)placePickerViewController:(FBPlacePickerViewController *)placePicker handleError:(NSError *)error; @end