This week I launched hopscotch.fm. It is still a very early stage site and there are many things I’d like to add on and improve, but I decided I needed to draw a line in the sand and just ship something. Anything.
In this blog post I want to give a general sense of how I went from idea to v1.0 going live.
Step 1: Proof of Concept
In this phase I wanted to rule out any potential major unknowns. The two biggest ones were:
- could I use Songkick’s API for my show listings
- could I build a radio player around Youtube videos
The first one was answered fairly quickly. The Songkick API features loads of shows and venues and while it’s not the cleanest data (dates are not always proper), it is a great start.
The second was a bit more involved. I want to make hopscotch.fm a radio player so that when a song completes, it automatically moves on to the next song without the user doing anything. I found a great library tubeplayer.js that did this.
Step 2: Get an ugly site up and running
It doesn’t have to be ugly, but I wasted no time in making anything look good. I had buttons all over the page, images showing up over controls and other oddness. But I got the functionality implemented. The user hits play and:
- The Youtube video starts playing
- An artist image is downloaded via Youtube’s API
- Venue info is retrieved from Songkick
- Artist info is retrieved from Wikipedia. I since removed this as it was the wrong half the time.
Step 3: Decide what constitutes v1.0 and do it
It’s probably no surprise that this step took the most time as now I needed to start caring about error handling and CSS and data validation and everything else that makes a real site, real. I added Bootstrap, built a little admin page for syncing hopscotch data with Songkick. Made a best guess effort at what a clean, simple user experience could be and from feedback I’ve gotten, I think it’s a decent start.
Step 4: Hosting and stuff
I originally put it on heroku as they have a free starter level. But the 20 second startup time just to get the page to load is ridiculous so I’ve now switched to nodejitsu. Data is on mongolab. It’s all in the cloud. It’s all happy.
Step 5: Go see a show!
That’s what hopscotch.fm is for so why not?