// JavaScript Document
// Written by Chris Converse
// for Lynda.com

var currentPanel = 1;
var totalPanels = 0;
var autoPlay = true;
var timePassed = 0;
var timeToChange = 3;

function autoAdvance(){
	
	if (window.timePassed == window.timeToChange){
		window.timePassed = 0;
		if(window.currentPanel == window.totalPanels){
			currentPanel = 0;
		}
		if (autoPlay == true){
			jQuery('.marquee_nav a.marquee_nav_item:nth-child('+(window.currentPanel+1)+')').trigger('click');
		}
	}else{
		window.timePassed += 1;
	}
	jQuery('.timePassed').html('timePassed = '+window.timePassed); 
	jQuery('.autoPlay').html('autoPlay = '+window.autoPlay); 
}

jQuery(document).ready(function(){

	setInterval(autoAdvance, 1500);
	
	
	jQuery('.marquee_container').hover(
		function(){
			window.autoPlay = false;
			jQuery(this).removeClass('autoplay');
		},
		function(){
			window.autoPlay = true; window.timePassed = 0;
			jQuery(this).addClass('autoplay');
		}
	);


	// Generate Navigation links
	jQuery('.marquee_panels .marquee_panel').each(function(index){
		jQuery('.marquee_nav').append('<a class="marquee_nav_item" ></a>');
		totalPanels = index + 1;
		jQuery('.totalPanels').html('totalPanels = '+totalPanels);  
	});
	
	// Generate Photo Lineup
	jQuery('img.marquee_panel_photo').each(function(index){
		var photoWidth = jQuery('.marquee_container').width();
		var photoPosition = index * photoWidth;
		jQuery('.marquee_photos').append('<img class="marquee_photo" style="left: '+photoPosition+'" src="'+jQuery(this).attr('src')+'" alt="'+jQuery(this).attr('alt')+'" width="765" height="350" />');
		jQuery('.marquee_photos').css('width', photoPosition+photoWidth);
	});

	// Set up Navigation Links
	jQuery('.marquee_nav a.marquee_nav_item').click(function(){
		
		// Set the navigation state
		jQuery('.marquee_nav a.marquee_nav_item').removeClass('selected');
		jQuery(this).addClass('selected');
		
		var navClicked = jQuery(this).index();
		var marqueeWidth = jQuery('.marquee_container').width();
		var distanceToMove = marqueeWidth*(-1);
		var newPhotoPosition = navClicked*distanceToMove + 'px';
		var newCaption = jQuery('.marquee_panel_caption').get(navClicked);
		window.currentPanel = navClicked + 1;
		
		
		// Animate the photos and caption
		jQuery('.marquee_photos').animate({left: newPhotoPosition}, 1500);
		jQuery('.marquee_caption').animate({top: '340px'}, 500, function(){
			var newHTML = jQuery(newCaption).html();
			jQuery('.marquee_caption_content').html(newHTML);
			setCaption();
		});
	});
	
	// Preload all images, then initialize marquee
	jQuery('.marquee_panels img').imgpreload(function(){
		initializeMarquee();
	});

});

function initializeMarquee(){
	jQuery('.marquee_caption_content').html(
		jQuery('.marquee_panels .marquee_panel:first .marquee_panel_caption').html()
	);
	jQuery('.marquee_nav a.marquee_nav_item:first').addClass('selected');
	jQuery('.marquee_photos').fadeIn(1500);
	setCaption();
}

function setCaption(){
	var captionHeight = jQuery('.marquee_caption').height();
	var marqueeHeight = jQuery('.marquee_container').height();
	var newCaptionTop = marqueeHeight - captionHeight - 15;
	jQuery('.marquee_caption').delay(100).animate({top: newCaptionTop}, 500);
}

