//output_text = 'Am I running?!';

//document.writeln('<font face="Arial" size="4">' + output_text + '</font><Br><Br>');


//BEGIN jQuery
$(function(){


/*
 * jQuery Timer Plugin
 * http://www.evanbot.com/article/jquery-timer-plugin/23
 *
 * @version      1.0
 * @copyright    2009 Evan Byrne (http://www.evanbot.com)
 */

jQuery.timer = function(time,func,callback){
	var a = {timer:setTimeout(func,time),callback:null}
	if(typeof(callback) == 'function'){a.callback = callback;}
	return a;
};

jQuery.clearTimer = function(a){
	clearTimeout(a.timer);
	if(typeof(a.callback) == 'function'){a.callback();};
	return this;
};

	//PROMO SLIDER

	totalPromo = $('#promo_slider div').size();
	xPos = 0;
	currentPromo = 1;
	moose = true;
	autoMoose = true;
	promoDelay = 6000;
	easeIn = 'easeInExpo';
	easeOut = 'easeOutElastic';
	inSpeed = 400;
	outSpeed = 600;
	
	$('#promo_nav .next a').click(function(){
		if(moose==true && totalPromo>currentPromo){
			xPos = xPos - 700;
			currentPromo = currentPromo + 1;
			slideTo(xPos, 'right');
		}else if(moose==true){			
			currentPromo = 1;
			infiniteLoop('right');
		}
		return false;
	});
	
	$('#promo_nav .prev a').click(function(){
		if(moose==true && currentPromo>1){
			xPos = xPos + 700;
			currentPromo = currentPromo - 1;
			slideTo(xPos, 'left');
		}else if(moose==true){
			currentPromo = totalPromo;
			infiniteLoop('left');
		}
		return false;
	});
	
	function infiniteLoop(dir){
		
		moose = false;
		
		totalX = 700 - (700 * totalPromo);
		
		if(dir == 'left'){
			$('#promo_slider').prepend('<div class="promo_content">'+$('#promo_slider div.promo_content:last').html()+'</div>').css({left:-700}).animate({left:350},inSpeed,easeIn,function(){
				$(this).animate({left:0},outSpeed,easeOut,function(){
					$('#promo_slider').css({left:totalX});
					$('#promo_slider div.promo_content:first').remove();
					moose = true;
				})
			});
			xPos = totalX;
		}else if(dir == 'right'){
			$('#promo_slider').append('<div class="promo_content">'+$('#promo_slider div.promo_content:first').html()+'</div>').animate({left:totalX-350},inSpeed,easeIn,function(){
				$(this).animate({left:totalX-700},outSpeed,easeOut,function(){
					$('#promo_slider').css({left:0});
					$('#promo_slider div.promo_content:last').remove();
					moose = true;
				});
			});
			xPos = 0;
		}
	}
	
	$('#promo_panel').mouseenter(function(){
		$.clearTimer(promoTimer);
	});
	$('#promo_panel').mouseleave(function(){
		autoMagical();
	});
	
	var promoTimer = {};
	
	function autoMagical(){
		promoTimer = $.timer(promoDelay,function(){
			$.clearTimer(promoTimer);
			$('#promo_nav .next a').click();
			autoMagical();
		});
	}
	
	autoMagical();
	
	function slideTo(newX, dir){
		moose = false;
		if(dir == 'left'){
			halfX = newX - 350;
		}else{
			halfX = newX + 350;
		}
		$('#promo_slider').animate({left:halfX},inSpeed,easeIn,function(){
			$(this).animate({left:newX},outSpeed,easeOut,function(){
				moose = true;
				thumbState(true);
			});
		})
	}
	
	
	// THUMB NAV
	
	function thumbNav(){
		
		$this = $('#promo_thumbs');
		t = $('#promo_slider .promo_content').length;
		i = 0;
		e = 'easeInOutCirc';
		s = 300;
		
		$this.append('<ul id="thumbs_nav"></ul>');
		
		$('#promo_slider .promo_content').each(function(){

			html = $(this).html();
			$this.children('div').append(html).children('a:eq(' + i + ')').attr('href','#' + i );
			
			i++;
			
			$('#thumbs_nav').append('<li></li>');
			
			if(i==t){
				$this.find('img').attr('width','160').attr('height','60');
				thumbSlide();
				thumbState(true);
			}
		});
		
		$this.mouseenter(function(){
			$('#promo_slider .promo_content').stop([]).animate({paddingTop:88},s,e);
			$this.stop([]).animate({top:0},s,e);
			thumbState();
			$this.children('.corners').show();
		});
		
		$this.mouseleave(function(){
			$('#promo_slider .promo_content').stop([]).animate({paddingTop:0},s,e);
			$this.stop([]).animate({top:-88},s,e,function(){
				$this.children('.corners').hide();
			});
			$this.find('a').removeClass('on');
		});
		
		$('#promo_thumbs div a').click(function(){
			if($(this).hasClass('on') || moose == false ) return false;
			$(this).addClass('on').siblings().removeClass('on');
			
			thumbNum = parseFloat($(this).attr('href').substr(1));
			
			xPos = thumbNum * -700;
			
			if( currentPromo < ( thumbNum + 1 ) ){
				slideTo(xPos, 'right');
			}else{
				slideTo(xPos, 'left');
			}
			
			currentPromo = thumbNum + 1;
			
			thumbState();

			return false;
		});
		
		// When there are more than 4, we need some cool slidy stuffs

		function thumbSlide(){
			w = 182 * t;
			//offset = $this.offset();
			
			$this.children('div').css({width:w, marginLeft: '-' + Math.ceil( w / 2 ) + 'px'});
			
			/*$this.mousemove(function(e){
				xmouse = ( e.pageX - offset.left ) * 100 / 225;
				$this.scrollLeft(x);
			});*/
		}
		
	}
	
	function thumbState(e){
		$('#thumbs_nav li:eq(' + ( currentPromo - 1 ) + ')').addClass('on').siblings().removeClass('on');
		if( !e ) $('#promo_thumbs div a:eq(' + ( currentPromo - 1 ) + ')').addClass('on').siblings().removeClass('on');
	}
	
	
	if ( $.browser.msie && $.browser.version.substr(0,1) < 7 ){
		$('#promo_thumbs').remove();
	}else{
		thumbNav();
	}
	
	//EASING

jQuery.extend(jQuery.easing,{
	easeOutElastic: function (x, t, b, c, d) {
		var s=1.70158;var p=0;var a=c;
		if (t==0) return b;  if ((t/=d)==1) return b+c;  if (!p) p=d*.3;
		if (a < Math.abs(c)) { a=c; var s=p/4; }
		else var s = p/(2*Math.PI) * Math.asin (c/a);
		return a*Math.pow(2,-10*t) * Math.sin( (t*d-s)*(2*Math.PI)/p ) + c + b;
	},
	easeInOutExpo: function(x,t,b,c,d){
		if (t==0) return b;
		if (t==d) return b+c;
		if ((t/=d/2) < 1) return c/2 * Math.pow(2, 10 * (t - 1)) + b;
		return c/2 * (-Math.pow(2, -10 * --t) + 2) + b;
	},
	easeOutExpo: function (x, t, b, c, d) {
		return (t==d) ? b+c : c * (-Math.pow(2, -10 * t/d) + 1) + b;
	},
	easeInExpo: function (x, t, b, c, d) {
		return (t==0) ? b : c * Math.pow(2, 10 * (t/d - 1)) + b;
	},
	easeInOutCirc: function (x, t, b, c, d) {
		if ((t/=d/2) < 1) return -c/2 * (Math.sqrt(1 - t*t) - 1) + b;
		return c/2 * (Math.sqrt(1 - (t-=2)*t) + 1) + b;
	}
});
	
	//PRELOAD IMAGES
	
	$('img.preload').each(function(){
		imgLoad($(this));
	});
	
	function imgLoad(img){
		url = $(img).attr('href').substring(1);
		alert(url);
	}
	
//END jQuery
});
