/* Copyright (c) 2008 Kean Loong Tan http://www.gimiti.com/kltan
 * Licensed under the MIT (http://www.opensource.org/licenses/mit-license.php)
 * jFlow
 * Version: 1.2 (July 7, 2008)
 * Requires: jQuery 1.2+
 */
 
(function($) {

	$.fn.jFlow = function(options) {
		var opts = $.extend({}, $.fn.jFlow.defaults, options);
		var randNum = Math.floor(Math.random()*11);
		var jFC = opts.controller;
		var jFS =  opts.slideWrapper;
		var jSel = opts.selectedWrapper;

		var cur = 0;
		var maxi = $(jFC).length;
		// sliding function
		var slide = function (dur, i) {
			$(opts.slides).children().css({
				overflow:"hidden"
			});
			$(opts.slides + " iframe").hide().addClass("temp_hide");
			$(opts.slides).animate({
				marginLeft: (-1 * ( i * $(opts.slides).find(":first-child").width() - $('#header').offset().left)) + "px"}, 
				opts.duration*(dur),
				opts.easing,
				function(){
					$(opts.slides).children().css({
						overflow:"auto"
					});
					$(".temp_hide").show();
					
					
						
						
					
				}
			);
			
			
			/*
			var next;
			if (cur < maxi - 1)
				next = cur+1;
			else {
				next = 0;				
			}						
			alert(next);
			*/
			
			
			
			
		}
		$(this).find(jFC).each(function(i){
			$(this).click(function(){
				if ($(opts.slides).is(":not(:animated)")) {
					$(jFC).removeClass(jSel);
					$(this).addClass(jSel);
					var dur = Math.abs(cur-i);
					slide(dur,i);
					
					
					if((cur == 1 && i == 0) || (cur == 0 && i == 1))
						$('#blurb').slideFadeToggle(400, 'swing');
					
					
					
					cur = i;
					
					
					
					/*
					//alert(i);
					if(i == 0)
						$('#blurb').animate({opacity: 100, height: 'toggle'}, 400, 'swing');
						//$('#blurb').slideFadeToggle(400, 'swing');
						
					if(i == 1)
						$('#blurb').animate({opacity: 0, height: 0}, 400, 'swing');  
					
						//$('#blurb').slideFadeToggle(400, 'swing');
						
						//$('#blurb').hide();
					*/
					
					
			
				}
			});
		});	
		
		$(opts.slides).before('<div id="'+jFS.substring(1, jFS.length)+'"></div>').appendTo(jFS);
		
		$(opts.slides).find("div").each(function(){
			$(this).before('<div class="jFlowSlideContainer"></div>').appendTo($(this).prev());
		});
		
		//initialize the controller
		$(jFC).eq(cur).addClass(jSel);
		
		var resize = function (x){			
			$(jFS).css({
				position:"relative",
				width: opts.width,
				height: opts.height,
				overflow: "hidden"
			});
			//opts.slides or #mySlides container
			$(opts.slides).css({
				position:"relative",
				width: $(jFS).width()*$(jFC).length+"px",
				height: $(jFS).height()+"px",
				overflow: "hidden"
			});
			// jFlowSlideContainer
			$(opts.slides).children().css({
				position:"relative",
				//width: $(jFS).width()+"px",
				height: $(jFS).height()+"px",
				"float":"left",
				overflow:"auto"
			});
			
			$(opts.slides).css({	
				marginLeft: (-1 * ((cur * $(opts.slides).find(":eq(0)").width() - $('#header').offset().left)) + "px")
			});
		}
		
		// put slide buttons back into each slide
		var i = 1;		
		/*$('.control').each(function(){		  
		  $('#slide' + i).append($(this));
		  i++;
		});*/
		
		$('.control').each(function(){		  
		  $('#slide' + i).append($(this));
		  $(this).hover(
		    function() {  
			  $(this).addClass('hover');  
			},  
			function() {  
			  $(this).removeClass('hover');  
			}  
		  );
		  i++;
		});
		   /*
		   1. $('*').hover(  
   2.  function() {  
   3.   $(this).addClass('hover');  
   4.  },  
   5.  function() {  
   6.   $(this).removeClass('hover');  
   7.  }  
   8. );  
		*/
		
		// sets initial size
		resize();

		// resets size
		$(window).resize(function(){
			resize();						  
		});
		
		
		
		$(opts.prev).click(function(){
			if ($(opts.slides).is(":not(:animated)")) {
				var dur = 1;
				if (cur > 0)
					cur--;
				else {
					cur = maxi -1;
					dur = cur;
				}
				$(jFC).removeClass(jSel);
				slide(dur,cur);
				$(jFC).eq(cur).addClass(jSel);
			}
		});
		
		$(opts.next).click(function(){
			if ($(opts.slides).is(":not(:animated)")) {
				var dur = 1;
				if (cur < maxi - 1)
					cur++;
				else {
					cur = 0;
					dur = maxi -1;
				}
				$(jFC).removeClass(jSel);
				slide(dur, cur);
				$(jFC).eq(cur).addClass(jSel);
			}
			
			
		});
	};
	
	$.fn.jFlow.defaults = {
		controller: ".jFlowControl", // must be class, use . sign
		slideWrapper : "#jFlowSlide", // must be id, use # sign
		selectedWrapper: "jFlowSelected",  // just pure text, no sign
		easing: "swing",
		duration: 400,
		width: "100%",
		prev: ".jFlowPrev", // must be class, use . sign
		next: ".jFlowNext" // must be class, use . sign
	};
	
})(jQuery);

   
   
   
      jQuery.fn.slideFadeToggle = function(speed, easing, callback) {
   
        return this.animate({opacity: 'toggle', height: 'toggle'}, speed, easing, callback);  
   
      };

