var github = (function(){ function render(target, repos){ var i = 0, fragment = '', t = $(target)[0]; for(i = 0; i < repos.length; i++) { fragment += '<li><a href="'+repos[i].url+'">'+repos[i].name+'</a><p>'+repos[i].description+'</p></li>'; } t.innerHTML = fragment; } return { showRepos: function(options){ var feed = new jXHR(); feed.onerror = function (msg,url) { $(options.target + ' li.loading').addClass('error').text("Error loading feed"); }; feed.onreadystatechange = function(data) { if (feed.readyState === 4) { var repos = []; for (var i = 0; i < data.repositories.length; i++){ if (options.skip_forks && data.repositories[i].fork) { continue; } repos.push(data.repositories[i]); } repos.sort(function(a, b) { var aDate = new Date(a.pushed_at).valueOf(), bDate = new Date(b.pushed_at).valueOf(); if (aDate === bDate) { return 0; } return aDate > bDate ? -1 : 1; }); if (options.count) { repos.splice(options.count); } render(options.target, repos); } }; feed.open("GET","http://github.com/api/v2/json/repos/show/"+options.user+"?callback=?"); feed.send(); } }; })();