(function($) {
	/*
		jquery.twitter.js v1.5
		Last updated: 08 July 2009

		Created by Damien du Toit
		http://coda.co.za/blog/2008/10/26/jquery-plugin-for-twitter

		Licensed under a Creative Commons Attribution-Non-Commercial 3.0 Unported License
		http://creativecommons.org/licenses/by-nc/3.0/
	
	*/

	$.fn.getTwitter = function(options) {

		$.fn.getTwitter.defaults = {
			userName: null,
			numTweets: 5,
			loaderText: "Loading tweets...",
			slideIn: true,
			slideDuration: 750,
			showHeading: true,
			headingText: "Latest Tweets",
			showProfileLink: true,
			showTimestamp: true,
			views: 4
		};

		var o = $.extend({}, $.fn.getTwitter.defaults, options);

		return this.each(function() {
			var c = $(this);

			// hide container element, remove alternative content, and add class
			c.hide().empty().addClass("twitted");

			// add heading to container element
			if (o.showHeading) {
				c.append("<h2>"+o.headingText+"</h2>");
			}

			// add twitter list to container element
			var twitterListHTML = "<ul id=\"twitter_update_list\"><li></li></ul>";
			c.append(twitterListHTML);

			var tl = $("#twitter_update_list");

			// hide twitter list
			tl.hide();

			// add preLoader to container element
			var preLoaderHTML = $("<p class=\"preLoader\">"+o.loaderText+"</p>");
			c.append(preLoaderHTML);

			// add Twitter profile link to container element
			if (o.showProfileLink) {
				var profileLinkHTML = "<p class=\"profileLink\"><a href=\"http://twitter.com/"+o.userName+"\">http://twitter.com/"+o.userName+"</a></p>";
				c.append(profileLinkHTML);
			}

			// show container element
			c.show();

			$.getScript("http://twitter.com/javascripts/blogger.js");
			$.getScript("http://twitter.com/statuses/user_timeline/"+o.userName+".json?callback=twitterCallback2&count="+o.numTweets, function() {
				// remove preLoader from container element
				$(preLoaderHTML).remove();

				// remove timestamp and move to title of list item
				if (o.showTimestamp) {
					tl.find("li").each(function() {
						var timestampHTML = $(this).children("a").attr("display","none");
						var timestamp = timestampHTML.html();
						timestampHTML.remove();
						$(this).prepend(timestampHTML);
						$(this).attr("title", timestamp);
					});
				}
				
				// Modified by 4creativeMedia, Dimitrios Dimiropoulos 			
				// add display none
				tl.find("li").css({"display":"none"});

				// show twitter list
				if (o.slideIn) {
					// a fix for the jQuery slide effect
					// Hat-tip: http://blog.pengoworks.com/index.cfm/2009/4/21/Fixing-jQuerys-slideDown-effect-ie-Jumpy-Animation
					var tlHeight = tl.data("originalHeight");

					// get the original height
					if (!tlHeight) {
						tlHeight = tl.show().height();
						tl.data("originalHeight", tlHeight);
						tl.hide().css({height: 0});
					}

					tl.show().animate({height: tlHeight}, o.slideDuration);
				}
				else {
					tl.show();
				}

				// add unique class to first list item
				tl.find("li:first").addClass("firstTweet");

				// add unique class to last list item
				tl.find("li:last").addClass("lastTweet");
				
				// Modified by 4creativeMedia, Dimitrios Dimiropoulos
				// Last updated: 29 Juni 2010
					var page = 0,
						maxpage = o.numTweets;
						
					function pageflip(start, ende){
						if(page>maxpage){ return false; }
						tl.find("li").fadeOut(200);
						tl.each(function(){
							for(i=start; i<start+o.views; i++){
								$(this).find("li:eq("+i+")").delay(200).fadeIn(200);
							};
							$(this).find('li:nth-child(4n+4)').css({'border':'none'});
						});
						if(page/o.views >= Math.floor(maxpage/o.views)){ 
							page=page; 
							$("#tweet-next").attr("disabled", "disabled").css("opacity",0.6); return false; 
						} else { 
							$("#tweet-next").removeAttr("disabled").css("opacity",1); 
						}
						if(page<=0){ 
							page=0; 
							$("#tweet-prev").attr("disabled", "disabled").css("opacity",0.6); 
							return false; 
						} else { 
							$("#tweet-prev").removeAttr("disabled").css("opacity",1); 
						}
					}
						
					tl.append("<br /><div id='wrapper-pageflip'><input type='button' id='tweet-prev' >&nbsp;<input type='button' id='tweet-next'><span>Nachrichten bl&auml;ttern</span></div>");
				
					$("#tweet-next").click(function(){
						page = parseInt(page)+o.views;
						pageflip(page);
					});
					$("#tweet-prev").click(function(){
						page = parseInt(page)-o.views;
						pageflip(page);
					});
					
					pageflip(page, maxpage);
				
			});
		});
	};
})(jQuery);
