#Assignment 10: Angular: AJAX and Dependency Injection
- Go to the "assignment10" repository on the CWEB221 GitHub page. Assignment instructions are in the readme below.
- Click "Fork" to fork this repository into your own account.
- Open the GitHub app and clone the forked repo to your computer.
- Complete the assignment per the instructions.
- Once the assignment is completed, go back to the GitHub app. Commit and sync your changes back to GitHub.
- Go back to the GitHub website, and go to the forked version of the "assignment10" repo on your account page (NOT the CWEB221 page). Click "Pull Requests," then "New pull request," then "Create pull request." You're done!
- Time to find the International Space Station again! Much like assignment #6, the goal of this assignment is to display on a map the location on Earth that the ISS is currently above -- but this time, we'll use Angular.
- IMPORTANT: work within Cloud9 or from a local server. The AJAX functionality won't work if you run it from a file only.
- Open "index.html" and "editme.js". Inside, you'll find a structured (but non-working) Angular application skeleton. The URLs for Open Notify (the ISS API) and Google Maps are commented in the file.
- In the HTML file, add the appropriate ng-app and ng-controller directives.
- Using Angular's dependency injection system, inject $scope and the $http service into the controller.
- Using the Open Notify API and the $http Angular service, make an AJAX call to retrieve lat/long coordinates for the space station, and add the resulting data to our $scope, so that the map placeholder in our HTML is populated correctly (hint: you can construct the entire URL in JavaScript and insert it, or put the URL in the HTML and just fill in the appropriate values).
- If all goes well, you should see a map with a marker indicating the ISS's current position when you open "index.html" in a browser.
- So far, our code will only run once. Add functionality that will allow the page to refresh(hint: add a button or use JavaScript's built-in setTimeout method to automatically refresh the AJAX data).
- Submit the completed project via GitHub pull request before the beginning of next week's class (04/29/15).
- Successfully add ng-app and ng-controller directives to HTML: 2pts.
- Use Angular's dependency injection to add $http and $scope to the controller: 2pts.
- Use $http to retrieve Open Notify data, and successfully update the Google Static Map: 2pts.
- Create mechanism to refresh data: 1pt.
- Turned in on time via a GitHub pull request: 3pts.