When Brian Zubert approached me with a great idea he had, to create an app for Herrle’s Country Farm Market I was pretty excited to help out. He explained to me the premise of what needed to be built: a simple app that wrapped a few pages from Herrle’s existing website, did some basic integration with core apps, and highlighted Herrle’s existing social channels. This approach offered an easy way for them to have a presence on the platform, and since their website already uses a responsive design they could make use of their existing web assets and resources.
Web or Native?
When it came down to choosing which platform to build the app in, my initial thought was that I could do it really fast using BlackBerry WebWorks, and I could have, but when it was mentioned that perhaps I could use Cascades, and QML I was intrigued.
By making use of WebViews in Cascades, I was able to get the best of both web and native worlds: an app that displayed web content, driven by a sleek Cascades chrome. What was especially great about this approach was that it allowed Herrle’s to update their website at will, and the app automatically displayed the new content to users.
This past week we published some amazing resources, the Built for BlackBerry Boilerplate templates, for both WebWorks and Cascades. These boilerplates allow developers to rapidly develop an app that possesses the signature BlackBerry 10 look and feel the users have come to expect. While in this case I wasn’t necessarily looking to create a true Built for BlackBerry app, the boilerplate still provided me with a solid place to start right out of the box.
To get started, I downloaded the Cascades Built for BlackBerry Boilerplate sample and imported the project into Momentics. That’s really about it, beginning was that easy. Within 2 minutes I had an app that integrated with BBM (Invite to download, BBM Channels), the Invocation framework (for sharing content to Facebook, Twitter, etc.) and had features like Window Covers, Splash Screens, Application Menu (swipe down), etc. As a web guy, this was a great place for me to start modifying the code, and more importantly learn from.
The next step was to figure out how I wanted the application to function. I really didn’t want to hard code a ton of information, or any for that matter, into the app itself because perhaps we’d end up reusing it in the future. Again, I looked back to my web roots and what came natural to me (no, not XML, how dare you!) and decided to use JSON to store all of app settings. For bonus points, I even created a handy web form to generate the JSON for me.
Since nearly everything in the app needed to be dynamic, the entire app was customizable, including the text labels for Tabs and which URL the tab would load. Extra details were also stored in the settings JSON like Herrle’s Twitter username, Facebook page, and even a unique UUID, which is needed during BBM registration.
The web form provided two output methods; Download JSON or Display JSON, in the end all that really matters is that JSON data is stored in a file aptly named settings.json within the assets folder of the project.
And with that, an app is born! Check out the Herrle’s Country Farm Market app in BlackBerry World
I learnt quite a bit during the development process.
If you find this post useful, have questions, or just want to keep up-to-date on the world of BlackBerry Development, follow me on Twitter @chadtatro
Built for BlackBerry “Boilerplates”