I use FullCalendar and populate the calendar from ajax call.
] [{"ID": "18", "name": "r2222", "start": "2012-10-02 8:00:00", "end": "2012-10-02 11:00: 00 "," TextColor ":" # 000000 "," AllDay ": false," color ":" # FFFFFF "},
{"identifier": "1", "name": "Test 123", "start": "2012-10-16", "end": NULL, "TextColor": "# 000000", "AllDay" false " color ":" # FFFFFF "},
{"ID": "16", "name": "happy gallown", "start": "2012-10-31", "end": "2012-10-31", "TextColor": "# fffcfc" , "AllDay": true, "color": "# d92727"},
{"identifier": "17", "name": "repeated", "start": "2012-10-03 19:00:00", "end": "2012-10-03 21:00:00" , "TextColor": "# 000000", "AllDay" false "color": "# ff56ff"}]