Exercise 1: Make an existing website mobile-friendly and print-friendly (25%)
For this exercise, find a website that has no mobile-friendly version, and a
website that does not print well (these may **not** be the same website),
and write CSS to make them mobile friendly (20%) and print-friendly (5%) respectively.
This exercise is similar to Exercise 4 in [HW6](../hw6), but will teach you a different set
of skills as you probe the web and find where designs can go wrong. For this exercise, you
can use the Chrome Dev Tools to experiment with CSS modifications and the Stylus extension to save your changes.
Most likely, the website you find that is not mobile friendly, will also not have a ``.
You can add that either manually in the Elements panel, or via this bookmarklet. We will grade your homework after adding it.
**Tip**: Avoid websites that are so old that they use tables or frames (!) for layout — it's much harder to change those with CSS.
**Deliverable:** Two stylesheets, one for making the website of your choice mobile friendly
and one for making it print-friendly.
Include the website each stylesheet is about in a comment at the top of the CSS file, as well as which pages
you tested your stylesheet on (at least three, unless it's a single-page website).
Exercise 2: Paper prototype a chat/IM app (20%)
The myriad of chat apps being out there and each having their own user base can tell us one thing: that
there is perhaps no perfect chat app yet and that the existing apps each have their own grievances.
In this assignment, we want you to think how you would design a chat app that fixes some of the usability problems
you found in Exercise 4 of [HW5](../hw5), integrates the best characteristics of the apps you compared, and goes
further to improve on them.
You could also try more radical improvements, such as adding tags or arbitrary properties to messages.
These are only examples, please try to come up with your own ideas. Think outside the box!
Justify your improvements through heuristic evaluation features or other usability principles we have learned.
You can reference your HW5 to avoid repetition if you raised the issue there.
Create at least two different paper prototypes of your chat app.
**Deliverable:** Photos or video of your prototypes and a simple HTML page that presents them and justifies the improvements (1-2 sentences max per improvement).
Exercise 3: User testing of calculator Balsamiq/Figma mockup (20%)
For this part of the assignment you will do a user testing session of your
Balsamiq/Figma calculator mockup from exercise 3 of [HW5](../hw5). The participant in your testing session
does not need to be a student. It can be anyone you know including a friend or family member.
Prepare for the user testing by writing a list of three tasks for your user to perform with your medium fidelity mockup.
During the study, you will ask your participant to perform three tasks. Using Balsamiq or Figma
you can add some interactivity to your design which will help you discover issues
your users might have that involve interactions with your design.
While the user is performing tasks, try to jot down notes about their behavior and questions.
These will be helpful for recalling insights in your writeup.
**Deliverable:** An HTML page with a short video of your user performing tasks
with your medium fidelity mockup, and a write up with your three tasks, insights from the user testing,
plans for changes, and raw user testing notes in an appendix at the end.
Exercise 4: HTML/CSS mockup of calculator (25%)
Now that you have iterated on your calculator design, it is time to implement
a high fidelity HTML & CSS prototype. This prototype must look like
your intended interface but need not provide functionality.
**Deliverable:** Your HTML & CSS prototype of the calculator. Include a short description of
how you improved your design after user testing in Exercise 3 in comments,
either at the top of the HTML file, or near relevant parts.
Exercise 5: Create a bookmarklet that reveals saved passwords (7%)
Bookmarklets are bookmarks with `javascript:` URLs that execute Javascript code on the current page when invoked.
We have seen how to create one in lecture.
For this exercise, you will create your own bookmarklet.
Often, when you visit websites where the browser has saved your password, it's hard to know what your password actually is, since it shows up as •••••.
However, if you inspect the HTML with dev tools, you can change `type="password"` to `type="text"` (or remove it altogether) and it just becomes a normal, readable, text field.
Write a bookmarklet that does this for all password fields on a page when invoked, so that one does not need to use dev tools for it.
**Deliverable:**
An HTML page with your bookmarklet code AND a link that can be dragged to the bookmarks toolbar to utilize the bookmarklet.
Exercise 6: HW 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 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.