#Project 8 - Shakespearean Insult Generator
##Do Now Begin this session by completing the Do Now activity.
##Scope To capitalize on the viral fury of the underground 'Shakespearean Insult' battle scene, you have been tasked by Cheesy Jokes Inc. with designing and creating a webapp to help users find the best Shakespearean insult to help them be victorious.
##Project Criteria Your Manager has laid out the following requirements for the project:
- Implement a mock API to retreive the insults
- Allow users to interact with the application to get a new insult
- Implement the ability to convert the insult to a voice text
##Learning Objectives By the end of this project the employee will be able to...
- Understand the difference between a GET and POST requests (HTTP Methods)
- Interpret the supplied API documentation and use the API for the application (APIs)
- Understand the role of the client and the role of the server (Client-Service Interaction)
- Understand how the client and the server interact (Client-Server Interaction)
- Analyze and interpret the supplied documentation to their project (Reading Comprehension)
- Ability to explain and discuss projects in terms of APIs and HTTP requests (Technical Vocabulary)
##References/Tools
##Vocabulary
- Application Program Interface (API)
- GET Requests
- POST Requests
- AJAX Requests
- Client
- Server
- Endpoint
##Instructions You are given a stripped-down project (starter code) to add the required functionality, which must be cloned into your own workspace. And make sure to read the comments!
###1) API Creation
####Why do I need this:
As a developer, you will rely on components created by other people or other teams. One way to interact with other components is through a systematic interface - known as the API (Application Programming Interface). An API provides a set of specific formats for the interaction between the callee and the caller - such as specifying the required inputs, the expected outputs, and possible error cases. Some APIs return information about products and recommended products (Amazon), post updates to social networks (Twitter or Facebook), or send money to your friend (Paypal, Venmo, etc.).
####What am I going to do:
In this step, you will step into the role of an architect and create an API used by your website to retreive insults from the service. The API will need to specify the inputs and the output, as well as mocking the expecting output (pretending to be the server and returning an output).
####Creating Mock Endpoint
- Go to mockable.io
- Click "Try Now"
- Select "DEFINE A NEW REST API"
- Creating an endpoint
- Set Path - Set the path you want to hit to get the list of Shakespearean insults. This shouldn't have any spaces and should describe the data the user is fetching. Something like "insults", "jokes", or "shakespeare" would make sense.
- Set Verb - The verb is just the type of HTTP request we want to make. We'll be using the GET verb because we're just fetching data from the backend. If we wanted to store data in the backend we'd probably use the POST verb.
- Set Response Body - This is what the backend will return to us when we make a request to this endpoint. Try pasting in the following JSON (JavaScript Object Notation):
[
{
"insult": "I scorn you, scurvy companion. What, you poor, base, rascally, cheating, lack-linen mate! Away, you moldy rogue, away!"
},
{
"insult": "Thou mewling toad-spotted miscreant!"
},
{
"insult": "[Thou art] a most notable coward, an infinite and endless liar, an hourly promise breaker, the owner of no one good quality."
},
{
"insult": "Thou puking rump-fed ratsbane!"
},
{
"insult": "Thou jarring beef-witted flap-dragon!"
},
{
"insult": "Methink'st thou art a general offence and every man should beat thee."
}
]
-
Click "Save" at the bottom of the screen
-
Starting the endpoint
-
You should see the endpoint you just created with a red button on the left that says "Stopped". It should look like this:
-
Click the "Stopped" button to make your endpoint live! The button should now look like this:
-
Now we should test out the endpoint. Click on the link underneath the "Name" column. It should take you to a page that looks like this:
-
Click on one of the links in this section and make sure it takes you to a page with the JSON you had entered for the Response Body
-
IMPORTANT - Your temporary account will expire in a day, so you if you want your mockable.io endpoint to keep working you must create an account in order to keep this API available. Don't worry! It's free! Here's how you do it:
-
Click the "Tell me more" link which will take you to the next screen.
-
Click one of the icons at the bottom of the screen to sign in (Google, Facebook, or StackExchange).
![LoginIcons](http://i.imgur.com/pZo0Kjj.png)
- You should now have a working endpoint for your project! Congratulations!
###2) Adding User Interface
####Why do I need this:
If you look at Facebook, you notice that users can submit comments or like a post without
requiring the page to reload. This ability to get information or perform an action without a page
reload provides a better, more seamless experience for users.
####What am I going to do:
You will implement the ability to show a new insult to the user without the need of reloading the
entire page
####How I will do this:
- Add a button to index.html which will be used to trigger a new insult.
- Add an area in index.html to display the insult text.
- In main.js, write a function to fetch insults from the server.
- Write a function to take the server response and store it locally.
- Call the fetch function when the script runs.
- Create an event handler for the button so that clicking the button triggers a new insult.
- Write a function to retrieve a random insult from the insults array.
- Write a function to display the insult on the screen.
###3) Speech Implementation
####Why do I need this:
This is a natural extention of the previous two steps. You will be add another method of
interaction by providing the user the ability to hear the insult, instead of reading the insult. To avoid
the need to build out an entire system to convert text to speech, this functionality will use the Web
Speech's API to convert text to audio.
####What am I going to do:
You will implement a method to use Web Speech's API based on their documentation (with
assistance from the web) to voice out the text.
#####How I will do this:
- In speak.js, use the text to voice javascript API to speak a string of text.
- Back in main.js, use the function you just wrote to speak the insult as it's displayed.
##Bonus Criteria Your Manager has offered a stipend of $500 for each of the bonus requirements listed below:
- Make the same project but with motivational statements instead of Shakespearean insults
- Figure out a way so you don't reuse any of the insults until the user has gone through them all (but keep their order random!).
- Make a magic 8-ball project that returns a different answer each time. If you're using a mobile device, you could have it give a different answer each time you shake or add an 8-ball animation each time it gives a new answer.
##Grading Criteria Your manager will be grading your capibility on this project based on this rubric
##How to Submit The final code for this project must be pushed back up to your repo on GitHub. Then share the link to your repo at the project submission link found in the header of the Daily Session Document (bit.ly/ScriptEd).
To push to GitHub run the following commands in your terminal:
git status
git add .
git commit -m "example comment"
git push origin master
##Homework Instructor will assign homework based on progress in class.