GuanxinLi / yelp_clone

A clone version of Yelp

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Project 3 - yelp_clone

yelp_clone is a Yelp search app using the Yelp API.

Time spent: X hours spent in total

User Stories

The following required functionality is completed:

  • Table rows for search results should be dynamic height according to the content height. (3pt)

Video Walkthrough

  • Custom cells should have the proper Auto Layout constraints. (+5pt)

  • Search bar should be in the navigation bar (doesn't have to expand to show location like the real Yelp app does). (+2pt)

The following stretch features are implemented:

  • Infinite scroll for restaurant results. (+3pt)
  • Implement map view of restaurant results. (+3pt)
  • Implement the restaurant detail page. (+2pt)

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):

Video Walkthrough

Here's a walkthrough of implemented user stories:

Video Walkthrough

GIF created with LiceCap.

Notes

Describe any challenges encountered while building the app.

License

Copyright [2018] [Guanxin Li]

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.

Basic Yelp client

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.

Next steps

  • Check out BusinessesViewController.swift to see how to use the Business model.

Sample request

Basic search with query

Business.searchWithTerm("Thai", completion: { (businesses: [Business]!, error: Error!) -> 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: Error!) -> Void in

    for business in businesses {
        print(business.name!)
        print(business.address!)
    }
}

About

A clone version of Yelp


Languages

Language:Swift 97.7%Language:Ruby 2.3%