I was reading Things a little bird told me by Twitter co-founder Biz Stone the other day. I will review the work later but what stuck out as the take-away message is:

Constraints drive innovation.

Over at Bitswits - the startup that I have been running for the past couple of years, the biggest problem is HR. We cannot for the life of us get decent Python let alone Django developers in Pakistan. It seems .NET has a death grip on the campuses.

On the other hand, it is significantly easier to hire good front-end people with some experience in templating. As a result, during the past year or so, Bitswits have evolved a spin on Django’s MVT (Model-View-Template) separation that we like to call M/V/T.

Essentially, a serious dearth of good Python hackers forces us to push every bit of presentation logic out to the templates. We do this by making template-composable web components.

Coffee Table is one such project. Now I am not a big fan of re-inventing the wheel. So I thoroughly fiddled away at all the alternatives. Unfortunately, following example represents the state of affairs:

class SimpleTable(Table):
	class Meta:
        model = Simple
        attrs = {'class': 'mytable'}
        sequence = ('name', 'surname')

Enough said. Now take a look at the equivalent Coffee Table syntax. Remember that we are not writing Python anymore. This takes place in Django templates:

{% coffee_table 
	field_accessors='name, surname' 
	table_class='table table-condensed' 

And this is just the start. Following example shows off the full set of options:

{% coffee_table 
	field_accessors='name, surname'
	table_class='table table-condensed'

The result: HTML table that can be composed by HTML people. Problem solved.

So you ask: Wonderful! now how the heck do I use this? Well, you can get Coffee Table via cheese shop:

pip install django_coffee_table

Include coffee_table in your INSTALLED_APPS. Set up dependencies according to their respective docs:

  • linaro-django-pagination
  • django-resort
  • django-tag-parser

Now load up the template tags and rock-on like so:

{% load coffee_table %}
{% coffe_table objects %}

If you find any issues, bones to pick, pat on the back or any other such business, head right over to Github and shout.