Assignment 10

Due

Exercise 1: Adding Prototype Functionality using JS for Chat/Messaging App (52%)

In [HW 9 Exercise 2](../hw9/#exercise-2-htmlcss-js-for-chatmessaging-app-74) you implemented basic functionality in your HTML/CSS prototypes for the Chat/Messaging App. This week you will be adding the functionality from your prototypes to the Chat/Messaging App. Here are some examples of functionality students mentioned in their prototypes. - custom ui settings such as themes or chat colors - custom message UI - threads - polls - Media (image/gif/video) - subject lines - group chats Your final submission should retain the ability to send, receive, and delete messages as well as display a collection of messages which you implemented in the previous assignment. In addition your submission should include at least 2 pieces of functionality from your prototyping design phase. If you think that it is impossible to implement the functionality from your design phase reach out to the course staff. The client application we developed should be flexible enough to meet most use cases. We will be grading you on usability, design, and the quality of your code implementation. The [documentation](../hw9/js/docs) will be very helpful for understanding the client. Especially the [home page](../hw9/js/docs/index.html) and [client page](../hw9/js/docs/Client.html).
You will need to manually trust the certificate on the messaging server. Check out the warning in [HW 9 Exercise 2](../hw9/#exercise-2-htmlcss-js-for-chatmessaging-app-74) if you have any trouble with this.

Per the course's [collaboration policy](/collaboration.html) that "your code must be your own", you are not allowed to use Javascript libraries or frameworks. However, we will consider allowing certain specific-purpose libraries if they enable interesting UI prospects that would otherwise require a large amount of vanilla JS code and effort.

**Deliverable:** Your customized prototype of the chat/messaging app. Include a short description of what functionality is added from your prototypes either at the top of the HTML file, or near relevant parts.

Exercise 2: Improving color & typography on your website (15%)

Use what we learned about color & typography to improve those aspects of your personal website that you've worked on in [HW1](../hw1/#ex2), [HW5](../hw5/#exercise-1-adding-css-to-your-hw1-homepage-33), and [HW6](hw6/#exercise-4-make-your-homepage-more-universal-30). Make at least 5 improvements and point them out in a short writeup (~1 sentence for each improvement).

Exercise 3: Evaluation of recipe UIs (30%)

- **If you cook:** Find a recipe of something you'd like to cook with > 5 steps and > 10 ingredients total (large enough that the recipe doesn't all fit in your viewport). Pick something you haven't cooked before or it's been a while since you've cooked, not something you cook several times a week and know by heart already. Preferably, pick a recipe on a large recipe website, not a blog, since those are too variable and can often have very egregious UI issues which would prevent you from doing a more meaningful evaluation. Cook it and film your screen while following the recipe. - **If you don't cook:** Video call a friend or relative who cooks and record their screen while following a recipe that satisfies the criteria above. Encourage them to think aloud, like a user test. Keep notes of what parts of the recipe UI you thought could use improvement, and brainstorm ideas to improve them. Think about the following: - How easy was it to find the recipe? - How easy is it to learn this new recipe by following it? - How quick is it to follow? Do I have to keep going back and forth? - How easy is it to find the information I have to keep looking at again and gain? - How does the UI and content prevent me from making mistakes? - What UI would facilitate shopping for ingredients more easily? - What UI improvements would make it easier to calculate nutritional information to comply with a certain nutritional plan (e.g. keeping carbs below 20g)? - What would make things easier for you when you make this dish again? Visit a few (> 3) other recipe websites (some examples: [Epicurious](https://www.epicurious.com/), [AllRecipes](https://www.allrecipes.com/), [FoodNetwork](https://www.foodnetwork.com/), [SimplyRecipes](https://www.simplyrecipes.com), [BBC Good Food](https://www.bbcgoodfood.com/) ). Are the issues you spotted present there too? Would your proposed improvements work there as well?
**Deliverable:** An HTML file with: - Link to recipe - Video of screen during cooking. Please speed up by at least 200% and cut off parts where nothing is happening to reduce filesize. No sound needed. - Photo of dish :) - Short writeup with comparison of recipe UIs and answers to the questions above - List of ideas for UI improvement and (optionally) one or more prototypes to illustrate them.

Exercise 3A (Alternate): For those who dislike food (30%)

**Do this OR Exercise 3 above, not both.** Consider some information management or navigation task you (or a friend) do with some frequency. Managing and playing music in a playlist; planning a collaborative project; booking travel or a vacation; finding a new restaurant under constraints, organizing a party; maintaining an inventory of your books; choosing your courses; hunting for a job; scheduling a meeting with several participants. Similar to the description in Exercise 3, select some web site that is typically used for the task you're considering and spend half an hour carrying out a suitable task. Alternatively, have a friend carry out the task and "think aloud" as they are doing so. Film your or your friend's screen while carrying out the task. To set up for next week's assignment, the web site you use **must offer an API** for accessing data available on that web site---e.g., there is an API for searching YouTube videos, another for Google Books or Calendar, others for searching restaurants on Yelp or products on Amazon. All the social media sites offer APIs as well. If you are unsure, google "[site name] api" and see if any official resources from the website itself comes up. E.g. if you search "yelp api" you will find the [official Yelp API docs](https://www.yelp.com/developers). Keep notes of what parts of the UI you thought could use improvement, and brainstorm ideas to improve them. Your ideas should extend beyond minor usability tweaks, instead considering changes of the scale outlined in Exercise 3. Visit a few (> 3) other big websites used for the task. Are the issues you spotted present there too? Would your proposed improvements work there as well?
**Deliverable:** An HTML file with: - Link to site - Video of screen during use. Please speed up by at least 200% and cut off parts where nothing is happening to reduce filesize. No sound needed. - Short writeup with comparison of UIs and answers to the questions above - List of ideas for UI improvement and (optionally) one or more prototypes to illustrate them.

Exercise 4: HW9 Feedback (3%)

Since this is a new class, we need your constructive feedback about every aspect of it: lectures, homeworks, recitations etc. Please go to this [google form](https://docs.google.com/forms/d/e/1FAIpQLSfGKp1fJe3tfzbSAWXbXRpkn5w6y4xOk7w77SS9xnraKv2-qw/viewform) and answer its questions.

Submitting your homework

Similar to the previous assignments, we are going to use Github Classroom again. Authorize Github Classroom here and accept the assignment, then follow the instructions there. Please follow the structure and naming of the starter repo, though you can add any additional files if you need them.

Make sure to update README.md with your Kerberos username, especially if it's different than your GitHub username.

If you push after the deadline, it will count towards your slack hours.