$(function() {
	
	var totalPanels		= $(".scrollContainer").children().size();
		
	var regWidth		= $(".panel").css("width");
	var regImgWidth		= $(".panel img").css("width");
	var regTitleSize	= $(".panel h2").css("font-size");
	var regParSize		= $(".panel p").css("font-size");
	
	var movingDistance      = 280;
	
	var curWidth		= 224;
	var curImgWidth		= 200;
	var curTitleSize	= "20px";
	var curParSize		= "15px";

	var $panels		= $('#slider .scrollContainer > div');
	var $container		= $('#slider .scrollContainer');
        
        var navegador = navigator.appName
        if (navegador == "Microsoft Internet Explorer")
            var navig="explorer";

	$panels.css({'float' : 'left','position' : 'relative'});
    
	$("#slider").data("currentlyMoving", false);

	$container
		.css('width', ($panels[0].offsetWidth * $panels.length) + 100 )
		.css('left', "-450px");

	var scroll = $('#slider .scroll').css('overflow', 'hidden');

	function returnToNormal(element) {
		$(element)
		    .end()
			.find("h2")
			.animate({ fontSize: regTitleSize })
			.end()
			.find("p")
			.animate({ fontSize: regParSize });
	};
	
	function growBigger(element) {
		$(element)
		    .end()
			.find("h2")
			.animate({ fontSize: curTitleSize })
			.end()
			.find("p")
			.animate({ fontSize: curParSize });
	}
	
	//direction true = right, false = left
	function change(direction) {
	   
	    //if not at the first or last panel
		if((direction && !(curPanel < totalPanels)) || (!direction && (curPanel <= 1))) { return false; }	
        
        //if not currently moving
        if (($("#slider").data("currentlyMoving") == false)) {
            
			$("#slider").data("currentlyMoving", true);
			
			var next         = direction ? curPanel + 1 : curPanel - 1;
			var leftValue    = $(".scrollContainer").css("left");
			var movement;
                        if(navig!="explorer")
                            movement = direction ? parseFloat(leftValue, 10) - movingDistance : parseFloat(leftValue, 10) + movingDistance;
                        else
                            movement = direction ? parseFloat(leftValue, 10) - movingDistance - curPanel/8 : parseFloat(leftValue, 10) + movingDistance + curPanel/8;
		
			$(".scrollContainer")
				.stop()
				.animate({
					"left": movement
				}, function() {
					$("#slider").data("currentlyMoving", false);
				});
			
			//returnToNormal("#panel_"+curPanel);
			//growBigger("#panel_"+next);
			
			curPanel = next;
			
			//remove all previous bound functions
			$("#panel_"+(curPanel+1)).unbind();	
			
			//go forward
			$("#panel_"+(curPanel+1)).click(function(){ change(true); });
			
            //remove all previous bound functions															
			$("#panel_"+(curPanel-1)).unbind();
			
			//go back
			$("#panel_"+(curPanel-1)).click(function(){ change(false); }); 
			
			//remove all previous bound functions
			$("#panel_"+curPanel).unbind();
		}
	}
	
	// Set up "Current" panel and next and prev
	//growBigger("#panel_3");	
	var curPanel = 3;
	
	$("#panel_"+(curPanel+1)).click(function(){ change(true); });
	$("#panel_"+(curPanel-1)).click(function(){ change(false); });
	
	//when the left/right arrows are clicked
	$(".right").click(function(){ change(true); });	
	$(".left").click(function(){ change(false); });
	
        //var nav = navigator.appCodeName;
        $(document).unbind('keypress');
        $(document).keydown(function(event){
                  switch (event.keyCode) {
                                case 13: //enter
                                        $(".right").click();
                                        break;
                                case 32: //space
                                        $(".right").click();
                                        break;
                                case 37: //left arrow
                                        $(".left").click();
                                        break;
                                case 39: //right arrow
                                        $(".right").click();
                                        break;
                  }
        });
        
        
	
});
