YelpClient is a Yelp search app using the Yelp API.
Time spent: 10 hours spent in total
The following required functionality is completed:
- Table rows for search results should be dynamic height according to the content height.
- Custom cells should have the proper Auto Layout constraints.
- Search bar should be in the navigation bar (doesn't have to expand to show location like the real Yelp app does).
The following optional features are implemented:
- Search results page
- Infinite scroll for restaurant results.
- Implement map view w/o restaurant results.
- Implement the restaurant detail page.
The following additional features are implemented:
- List anything else that you can get done to improve the app functionality!
Please list two areas of the assignment you'd like to discuss further with your peers during the next class (examples include better ways to implement something, how to extend your app in certain ways, etc):
Here's a walkthrough of implemented user stories:
GIF created with LiceCap.
Describe any challenges encountered while building the app.
Copyright [2017] [Mitchell Wong]
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.
This is a headless example of how to implement an OAuth 1.0a Yelp API client. The Yelp API provides an application token that allows applications to make unauthenticated requests to their search API.
- Check out
BusinessesViewController.swift
to see how to use theBusiness
model.
Basic search with query
Business.searchWithTerm("Thai", completion: { (businesses: [Business]!, error: NSError!) -> Void in
self.businesses = businesses
for business in businesses {
print(business.name!)
print(business.address!)
}
})
Advanced search with categories, sort, and deal filters
Business.searchWithTerm("Restaurants", sort: .Distance, categories: ["asianfusion", "burgers"], deals: true) { (businesses: [Business]!, error: NSError!) -> Void in
for business in businesses {
print(business.name!)
print(business.address!)
}
}