In a few weeks you’re going to be senior students… so it’s time to exit the walled garden of prepared exercises. For this project you have an empty repo and need to build everything yourself.
Make a chat client that loads in the browser, and looks like a typical message app. These are the requirements:
- The UI is divided in 3 parts. On the left side there are messages from other users. On the right side there are messages you wrote. On the bottom there’s an input with a button to send new messages.
- Your messages and the other users’ messages should have different background colors, come in a nice bubbly shape, and auto scroll to keep the relevant content on the screen as new messages come in.
- Automatically load new messages from other users, grabbing them from this programming quotes API (use the “random” mode). The messages should come in at random intervals within a time range of your choice.
- All messages should be instances of a
Message
class that has 3 properties:author
(string) - The author’s username (for this exercise the values can just be “me” or “other”).content
(string) - The message text.timeStamp
(number) - The creation timestamp in milliseconds.
To make the requests to the API install and use jQuery (you can save it as a dependency through Bower, or import it from the CDN).
First get your external quotes using Ajax (notice that the responses include a CORS header). Now switch to JSONP, and check the difference between the two methods.
Make sure to make small, incremental, and descriptive commits along the way. Before committing check your syntax through gulp lint
.
To install the required dependencies run npm install
.
Now create 3 files in the /app
folder:
index.html
- Includes your HTML structure, and the imports for any other required resources (e.g. scripts and CSS).style.css
- This is where your CSS rules go.script.js
- Here you add any JavaScript code for the client.
Now you can run the gulp
command from the project folder: this will open the browser on index.html
, and automagically reload the page any time you modify the HTML, CSS, or JS file (if you want to disable automatic syncing, you can do it from the control panel at http://localhost:3001/sync-options
).
- Add unit tests in the
/test
folder. First you’ll need to install Jasmine and save it as a dev-dependency in your project (read the docs and see how it works). In the same way, to test your DOM you can use jsdom. - Display the timestamp of each message in a user-friendly way, using the “relative time” feature of Moment.js.
- Improve the look and feel of your UI, go fancy, make it sexy!