Assignment 8

Due

Exercise 1: User testing of your Chat/Messaging App paper prototypes (20%)

For this exercise you will be user testing your Chat/Messaging App paper prototype from [HW7 Exercise 2](../hw7/#exercise-2-paper-prototype-a-chatim-app-20). This should start to feel familiar by now. You previously user tested your calculator paper prototypes in [HW6 Exercise 2](../hw6/#exercise-2-user-testing-of-your-paper-prototypes-20). Prepare for the user test by writing a list of three tasks for your user to perform with your paper prototype. (e.g. a task could be a certain expression you want your users to try and calculate). During the study you will ask your participant to perform three tasks. Your paper prototype is static but you can simulate interactivity for your test subjects by explaining what would happen if it were interactive. Your explanation can be verbal, but it can also include physically modifying your paper prototype using post it notes, index cards, or pencil markings. 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.
The participant in your testing session does not have to be a student. It can be anyone you know including a friend or family member. If it is not feasible for you to conduct in-person user testing, contact the staff and we will work with you to develop an alternative remote-testing plan.

**Deliverable:** An HTML page with a short video of your user performing tasks with your paper prototype, 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 2: Iterate and implement a Balsamiq/Figma mockup of your Chat/Messaging App (30%)

After performing some user testing on your paper prototype from [Exercise 1](#exercise-1-user-testing-of-your-chatmessaging-app-paper-prototypes-20), create a high fidelity balsamiq/figma mockup that includes at least three changes to address issues testers had with your low fidelity prototype. This mockup must look like your intended user interface but need not provide the functionality.
**Figma:** is [free for students](https://www.figma.com/education/) as long as you sign up with your MIT email. **Balsamiq for Desktop:** has a [30 day free trial](https://balsamiq.com/wireframes/desktop/).

**Deliverable:** An HTML page with a PNG or SVG of your Balsamiq/Figma mockup. Include a short description of your improvements in comments, either at the top of the HTML file, or near relevant parts.

Exercise 3: JS for Calculator (47%)

In this part of the assignment you will be using Javascript to add functionality to you the HTML & CSS prototype calculator you created in [HW7 Exercise 4](../hw7/#exercise-4-htmlcss-mockup-of-calculator-25). You do not need to use all of the HTML & CSS code from your prototype in your final submission and you can modify your HTML & CSS code as you see fit. But keep in mind the feedback you got in your user testing sessions as you add functionality and make design changes. Your final submission should be able to accomplish the following tasks as a minimum. - Perform basic arithmetic (`+, -, *, /`). - Allow the user to express grouping. For example, to calculate an expression such as `(1 + 2) * 3`. - Provide the ability to store and recall value(s). - Give the user the ability to perform at least 3 tasks beyond basic arithmetic. For example calculating an exponent, a logarithm, or a trigonometric function. We encourage you to be creative and go beyond the basic functionality outlined here.
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. If in doubt, ask on Piazza. So far we have whitelisted the following libraries, after student requests: - MathJax You do *not* need to use any libraries to earn full credit. In fact, we would recommend avoiding libraries if your UI doesn't require them, as that will teach you a lot more about JS.

**Deliverable:** Your functional prototype of the calculator. Include a short description of what functionality is included either at the top of the HTML file, or near relevant parts.

Exercise 5: HW7 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/1FAIpQLSdC85jimkHTN94FoKvLyhmNdJ1BjxAuJrY0cw2iYVpROe-j3w/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.