/*
 * Functions
 */
function getAjax(enlace,capa,param){
	$.ajax({
			url: enlace,
			dataType: "html",
			data: param,
			async: false,
			beforeSend: function (){
				capa.html("<img src='ajax-loader.gif' alt='Cargando'>");
			},
			error: function (objeto, quepaso, otroobjeto) {
				capa.html("<h4>Error al cargar el contenido. " + quepaso + ". Intente nuevamente. Disculpe las molestias." +  "</h4>");
			},
			success: function (data,estado,XMLData) {
				capa.html(data);
			}
	});
}

function slideSwitch() {
    var $active = $('#slideshow IMG.active');

    if ( $active.length == 0 ) $active = $('#slideshow IMG:last');

    var $next =  $active.next().length ? $active.next()
        : $('#slideshow IMG:first');

    $active.addClass('last-active');

    $next.css({opacity: 0.0})
        .addClass('active')
        .animate({opacity: 1.0}, 1000, function() {
            $active.removeClass('active last-active');
        });
}

/*
 * Load
 */
$(function(){
	
	$('#contacto_content').hide();
	$('#quienes_content').hide() ;

	/* Eventos del menu */    
	$(".menu, .submenu").hover(function() {
    	$(this).animate({ color: "#5CC9EE" }, 200);
                },function() {
                    $(this).animate({ color: "white" }, 400);
    });
   
    setInterval( "slideSwitch()", 5000 );

	/* Eventos de que */  
    $('#que').click(function(){ 
    	$('#que_content').show('slow') ;
     	$('#contacto_content').hide('slow');
    	$('#quienes_content').hide('slow') ;
    	getAjax('index.php',$('#que_titulo'),'accion=texto&d=ique&ext=tit');
		getAjax('index.php',$('#que_texto'),'accion=texto&d=ique&ext=txt');
		getAjax('index.php',$('#slideshow'),'accion=slideimage&d=ique&ext=img');
     }); 

    $('#contacto').click(function(){ 
    	$('#contacto_content').show('slow') ;
     	$('#que_content').hide('slow');
    	$('#quienes_content').hide('slow') ;
     }); 

    $('#quienes').click(function(){ 
    	$('#quienes_content').show('slow') ;
    	$('#contacto_content').hide('slow') ;
     	$('#que_content').hide('slow');
     }); 
    	
     $('#mp_content').click(function(){
    	    $('#pn_content').animate( { height: '300px' }, { queue: false, duration:500 });
    	 	$('#mp_content').animate( { height: '480px',top: '310px' }, { queue: false, duration:500 });
    	 });
 
     $('#pn_content').click(function(){
	 		$('#pn_content').animate( { height: '500px' }, { queue: false, duration:500 });
			$('#mp_content').animate( { height: '280px',top: '510px' }, { queue: false, duration:500 });
		});

     $('#gc_content').click(function(){
 	    $('#ag_content').animate( { height: '300px' }, { queue: false, duration:500 });
 	 	$('#gc_content').animate( { height: '480px',top: '310px' }, { queue: false, duration:500 });
 	 });

     $('#ag_content').click(function(){
	 	$('#ag_content').animate( { height: '500px' }, { queue: false, duration:500 });
		$('#gc_content').animate( { height: '280px',top: '510px' }, { queue: false, duration:500 });
	});

     $('#fh_content').click(function(){
  	    $('#lg_content').animate( { height: '300px' }, { queue: false, duration:500 });
  	 	$('#fh_content').animate( { height: '480px',top: '310px' }, { queue: false, duration:500 });
  	 });

      $('#lg_content').click(function(){
 	 	$('#lg_content').animate( { height: '500px' }, { queue: false, duration:500 });
 		$('#fh_content').animate( { height: '280px',top: '510px' }, { queue: false, duration:500 });
 	});
    
	//remove js-disabled class
	$("#viewer").removeClass("js-disabled");

	//create new container for images
	$("<div>").attr("id", "container").css({ position:"absolute"}).width($(".wrapper").length * 170).height(170).appendTo("div#viewer");
  	
	//add images to container
	$(".wrapper").each(function() {
		$(this).appendTo("div#container");
	});
	
	//work out duration of anim based on number of images (1 second for each image)
	var duration = $(".wrapper").length * 2000;
	
	//store speed for later (distance / time)
	var speed = (parseInt($("div#container").width()) + parseInt($("div#viewer").width())) / duration;
					
	//set direction
	var direction = "rtl";
	
	//set initial position and class based on direction
	(direction == "rtl") ? $("div#container").css("left", $("div#viewer").width()).addClass("rtl") : $("div#container").css("left", 0 - $("div#container").width()).addClass("ltr") ;
	
	//animator function
	var animator = function(el, time, dir) {
	 
		//which direction to scroll
		if(dir == "rtl") {
		  
		  //add direction class
			el.removeClass("ltr").addClass("rtl");
		 		
			//animate the el
			el.animate({ left:"-" + el.width() + "px" }, time, "linear", function() {
									
				//reset container position
				$(this).css({ left:$("div#imageScroller").width(), right:"" });
				
				//restart animation
				animator($(this), duration, "rtl");
				
				//hide controls if visible
				($("div#controls").length > 0) ? $("div#controls").slideUp("slow").remove() : null ;			
								
			});
		} else {
		
		  //add direction class
			el.removeClass("rtl").addClass("ltr");
		
			//animate the el
			el.animate({ left:$("div#viewer").width() + "px" }, time, "linear", function() {
									
				//reset container position
				$(this).css({ left:0 - $("div#container").width() });
				
				//restart animation
				animator($(this), duration, "ltr");
				
				//hide controls if visible
				($("div#controls").length > 0) ? $("div#controls").slideUp("slow").remove() : null ;			
			});
		}
	}
	
	//start anim
	animator($("div#container"), duration, direction);
	
	//pause on mouseover
	$("a.wrapper").live("mouseover", function() {
	  
		//stop anim
		$("div#container").stop(true);
		
		//show controls
		($("div#controls").length == 0) ? $("<div>").attr("id", "controls").appendTo("div#outerContainer").css({ opacity:0.7 }).slideDown("slow") : null ;
		($("a#rtl").length == 0) ? $("<a>").attr({ id:"rtl", href:"#", title:"rtl" }).appendTo("#controls") : null ;
		($("a#ltr").length == 0) ? $("<a>").attr({ id:"ltr", href:"#", title:"ltr" }).appendTo("#controls") : null ;
		
		//variable to hold trigger element
		var title = $(this).attr("title");
		
		//add p if doesn't exist, update it if it does
		($("p#title").length == 0) ? $("<p>").attr("id", "title").text(title).appendTo("div#controls") : $("p#title").text(title) ;
	});
	
	//restart on mouseout
	$("a.wrapper").live("mouseout", function(e) {
	  
		//hide controls if not hovering on them
		(e.relatedTarget == null) ? null : (e.relatedTarget.id != "controls") ? $("div#controls").slideUp("slow").remove() : null ;
		
		//work out total travel distance
		var totalDistance = parseInt($("div#container").width()) + parseInt($("div#viewer").width());
											
		//work out distance left to travel
		var distanceLeft = ($("div#container").hasClass("ltr")) ? totalDistance - (parseInt($("div#container").css("left")) + parseInt($("div#container").width())) : totalDistance - (parseInt($("div#viewer").width()) - (parseInt($("div#container").css("left")))) ;
		
		//new duration is distance left / speed)
		var newDuration = distanceLeft / speed;
	
		//restart anim
		animator($("div#container"), newDuration, $("div#container").attr("class"));

	});
									
	//handler for ltr button
	$("#ltr").live("click", function() {
	 					
		//stop anim
		$("div#container").stop(true);
	
		//swap class names
		$("div#container").removeClass("rtl").addClass("ltr");
							
		//work out total travel distance
		var totalDistance = parseInt($("div#container").width()) + parseInt($("div#viewer").width());
		
		//work out remaining distance
		var distanceLeft = totalDistance - (parseInt($("div#container").css("left")) + parseInt($("div#container").width()));
		
		//new duration is distance left / speed)
		var newDuration = distanceLeft / speed;
		
		//restart anim
		animator($("div#container"), newDuration, "ltr");
	});
	
	//handler for rtl button
	$("#rtl").live("click", function() {
							
		//stop anim
		$("div#container").stop(true);
		
		//swap class names
		$("div#container").removeClass("ltr").addClass("rtl");
		
		//work out total travel distance
		var totalDistance = parseInt($("div#container").width()) + parseInt($("div#viewer").width());

		//work out remaining distance
		var distanceLeft = totalDistance - (parseInt($("div#viewer").width()) - (parseInt($("div#container").css("left"))));
		
		//new duration is distance left / speed)
		var newDuration = distanceLeft / speed;
	
		//restart anim
		animator($("div#container"), newDuration, "rtl");
	});
});

