This exercise is intended to help the hiring team at Mass Relevance to gauge your level of front-end coding experience (HTML, CSS & JavaScript).
You should budget about an hour of actual coding time to complete the project. We realize that's a tight constraint, but we're trying to be respectful of your time while still allowing you to produce enough code for us to make a fair assessment of your skills. Try to ensure that the finished product represents your coding abilities, although you're not necessarily expected to fully finish in an hour. We'd much rather review high-quality but incomplete work rather than rushed, but complete work.
We've created a few starter files that you should flesh out:
and a PSD to use as a mockup.
You will be building an "Awesome Bands" leaderboard, which is a list of awesome band names paired with the number of times that those bands have been mentioned on Twitter.
For simplicity's sake, we've stubbed out an API interface and polling functionality within a library (see lib.js). The library provides a Poller()
class that allows you to create a poller, setting some options and providing a callback function that will be called when the poller returns data. It also has a .start()
method that will start the poller.
Upon each poll, the API will send an array of objects to your callback function. Each object will contain a band name and its associated count, sorted descending by count.
The leaderboard that you build should satisfy these basic requirements:
- Visually adhere to the provided PSD.
- Every 15 seconds, update the leaderboard to show the latest band names and counts, sorted descending by count.
- Bonus: Animate the leaderboard update in some way (fade/dissolve, sliding, etc.).
When you're finished, please send your work your Mass Relevance dev contact as a .zip file or (preferably) a link to a public repo on GitHub.
Please use your best judgment to interpret the requirements above. However, if you're stuck with a question(s), feel free to email your Mass Relevance dev contact. There are no bad questions (other than, "What does JavaScript mean?").