function twitterCallback(twitters) {
  var statusHTML = [];
  for (var i=0; i<twitters.length; i++){
    var username = twitters[i].user.screen_name;
    var status = twitters[i].text.replace(/((https?|s?ftp|ssh)\:\/\/[^"\s\<\>]*[^.,;'">\:\s\<\>\)\]\!])/g, function(url) {
      return '<a href="'+url+'">'+url+'</a>';
    }).replace(/\B@([_a-z0-9]+)/ig, function(reply) {
      return  reply.charAt(0)+'<a href="http://twitter.com/'+reply.substring(1)+'">'+reply.substring(1)+'</a>';
    });
    statusHTML.push('<li><span>'+status+'</span> <a style="font-size:85%" href="http://twitter.com/'+username+'/statuses/'+twitters[i].id+'">'+relative_time(twitters[i].created_at)+'</a></li>');
  }
  jQuery("#twitter_update_list").html(statusHTML.join(''));
}

function relative_time(time_value) {
  var values = time_value.split(" ");
  time_value = values[1] + " " + values[2] + ", " + values[5] + " " + values[3];
  var parsed_date = Date.parse(time_value);
  var relative_to = (arguments.length > 1) ? arguments[1] : new Date();
  var delta = parseInt((relative_to.getTime() - parsed_date) / 1000);
  delta = delta + (relative_to.getTimezoneOffset() * 60);

  if (delta < 60) {
    return 'less than a minute ago';
  } else if(delta < 120) {
    return 'about a minute ago';
  } else if(delta < (60*60)) {
    return (parseInt(delta / 60)).toString() + ' minutes ago';
  } else if(delta < (120*60)) {
    return 'about an hour ago';
  } else if(delta < (24*60*60)) {
    return 'about ' + (parseInt(delta / 3600)).toString() + ' hours ago';
  } else if(delta < (48*60*60)) {
    return '1 day ago';
  } else {
    return (parseInt(delta / 86400)).toString() + ' days ago';
  }
}

function init_rotation() {

var self = this;

this.nextFadeOut = function() {};

this.delayFadeOut = function() {
	jQuery("#rotating").animate( { width:"960px"}, 5000, function() {
		self.nextFadeOut();
	});
}

this.nextFadeOut = function() {
	jQuery("#rotating img:last-child").fadeOut("slow", function() {
		jQuery("#rotating img:last-child").prependTo("#rotating");
		jQuery("#rotating img").each(function(i) {
			jQuery(this).attr("style","z-index:" + i + ";");
		});
		self.delayFadeOut();
	});	
}

this.nextQuoteFadeOut = function() {};

this.quoteIndex = 1;

this.delayQuoteFadeOut = function() {
	jQuery("#quotes").animate( { width:"640px"}, 5000, function() {
		self.nextQuoteFadeOut();
	});
}

this.nextQuoteFadeOut = function() {
	jQuery("#quotes blockquote:nth-child(" + self.quoteIndex + ")").fadeOut("slow", function() {
		self.nextQuoteFadeIn(); 
	});	
}

this.nextQuoteFadeIn = function() {
	self.quoteIndex += 1;
	if (self.quoteIndex > jQuery("#quotes blockquote").size()) {
		self.quoteIndex = 1;
	}
	jQuery("#quotes blockquote:nth-child(" + self.quoteIndex + ")").fadeIn("slow", function() {
		self.delayQuoteFadeOut();
	});
}

jQuery(function() {
	delayFadeOut();
	nextQuoteFadeIn();
	Nifty("div.panel","big");
});
};

init_rotation();