harrystaley / UD_FEND-FSND_Neighborhood_Map

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Udacity Front End and Full Stack Web Developer Nanodegrees

Project: Neighborhood Map

PROJECT SPECIFICATIONS

as of July 2016

Interface Design

CRITERIA MEETS SPECIFICATIONS
Responsiveness All application components render on-screen in a responsive manner.
Usability All application components are usable across modern desktop, tablet, and phone browsers.

App Functionality

CRITERIA MEETS SPECIFICATIONS
Filter Locations via Text Input Includes a text input field that filters the map markers and list items to locations matching the text input. Filter function runs error-free.
List View A list-view of location names is provided which displays all locations by default, and displays the filtered subset of locations when a filter is applied.Clicking a location on the list displays unique information about the location, and animates its associated map marker (e.g. bouncing, color change.)List functionality is responsive and runs error free.
Map and Markers Map displays all location markers by default, and displays the filtered subset of location markers when a filter is applied.Clicking a marker displays unique information about a location in either an infoWindow or DOM element.Markers should animate when clicked (e.g. bouncing, color change.)Any additional custom functionality provided in the app functions error-free.

App Architecture

CRITERIA MEETS SPECIFICATIONS
Proper Use of Knockout Code is properly separated based upon Knockout best practices (follow an MVVM pattern, avoid updating the DOM manually with jQuery or JS, use observables rather than forcing refreshes manually, etc). Knockout should not be used to handle the Google Map API. There are at least 5 locations hard-coded in the model.

Asynchronous Data Usage

CRITERIA MEETS SPECIFICATIONS
Asynchronous API Requests Application utilizes the Google Maps API and at least one non-Google third-party API. Refer to this documentation. All data requests are retrieved in an asynchronous manner.
Error Handling Data requests that fail are handled gracefully using common fallback techniques (i.e. AJAX error or fail methods). 'Gracefully' means the user isn’t left wondering why a component isn’t working. If an API doesn’t load there should be some visible indication on the page (an alert box is ok) that it didn’t load. Note: You do not need to handle cases where the user goes offline.

Location Details Functionality

CRITERIA MEETS SPECIFICATIONS
Additional Location Data Functionality providing additional data about a location is provided and sourced from a 3rd party API. Information can be provided either in the marker’s infoWindow, or in an HTML element in the DOM (a sidebar, the list view, etc.) Provide attribution for the source of additional data. For example, if using Foursquare, indicate somewhere in your UI and in your README that you are using Foursquare data.
Error Free Application runs without errors.
Usability Functionality is presented in a usable and responsive manner.

Documentation

CRITERIA MEETS SPECIFICATIONS
README A README file is included detailing all steps required to successfully run the application.
Comments Comments are present and effectively explain longer code procedures.
Code Quality Code is formatted with consistent, logical, and easy-to-read formatting as described in the Udacity JavaScript Style Guide

About


Languages

Language:HTML 97.3%Language:JavaScript 2.4%Language:CSS 0.3%