/*
avec l'aide de http://www.guillaumevoisin.fr/blog/developpement/tutoriel-realiser-un-diaporama-simple-avec-jquery
 */

(function($){
	$.fn.diaporama = function(options) {
		var defaults = {
			delay: 5,
			animationSpeed: 'normal',
		};
 
		var options = $.extend(defaults, options);
 
		this.each(function(){
 
			var obj = $(this);
 
			if($(obj).find('li').length > 1){
				var inter = setInterval(function(){nextElt(options)}, (options.delay*1000));
				var sens = 'right';
				var pause = false;
 
				$(obj).find('li').hide();
				$(obj).find('li:first-child').addClass('active').fadeIn(options.animationSpeed);
				
				// Controls
                if(options.controls)
                {
                    $(obj).after("<div class='diaporama_controls'><div class='btns'><a href='#' class='prev'>Prec.</a> <a href='#' class='pause'>Pause</a> <a href='#' class='next'>Suiv.</a></div></div>");
 
                    $(obj).siblings().find(".prev").click(function(){
                        clearInterval(inter);
                        prevElt(options);
                        if(!pause)
                            inter = setInterval(function(){prevElt(options)}, (options.delay*1000));
                        sens = "left";
                    });
 
                    $(obj).siblings().find(".next").click(function(){
                        clearInterval(inter);
                        nextElt(options);
                        if(!pause)
                            inter = setInterval(function(){nextElt(options)}, (options.delay*1000));
                        sens = "right";
                    });
 
                    $(obj).siblings().find(".pause").toggle(
                        function(){
                            $(this).removeClass("pause").addClass("play");
                            clearInterval(inter);
                            pause = true;
                        },
                        function(){
                            $(this).removeClass("play").addClass("pause");
                            inter = setInterval(function(){ (sens == "right")?nextElt(options):prevElt(options)}, (options.delay*1000));
                            pause = false;
                        }
                    );
                }
				
				//hoverStop
				if(options.hoverStop)
                {
  
                    $(obj).hover(
                        function(){
							$(this).removeClass("pause").addClass("play");
                            clearInterval(inter);
                        },
                        function(){
						   inter = setInterval(function(){ (sens == "right")?nextElt(options):prevElt(options)}, (options.delay*1000));
						   pause = false;
                        }
                    );
                }
				
				// Affiche l'élément suivant
				function nextElt(options)
				{
					$(obj).find('li.active').fadeOut(options.animationSpeed);
 
					if(!$(obj).find('li.active').is(':last-child'))
					{
						$(obj).find('li.active').next().addClass('active').prev().removeClass('active');
						$(obj).find('li.active').fadeIn(options.animationSpeed);
 
					}
					else
					{
						$(obj).find('li:first-child').addClass('active').fadeIn(options.animationSpeed);
						$(obj).find('li:last-child').removeClass('active');
					}
				}
 
				// Affiche l'élément précédent
				function prevElt(options)
				{
					$(obj).find('li.active').fadeOut(options.animationSpeed);
 
					if(!$(obj).find('li.active').is(':first-child'))
					{
						$(obj).find('li.active').prev().addClass('active').next().removeClass('active');
						$(obj).find('li.active').fadeIn(options.animationSpeed);
 
					}
					else
					{
						$(obj).find('li:last-child').addClass('active').fadeIn(options.animationSpeed);
						$(obj).find('li:first-child').removeClass('active');
					}
				}
			}
		});
		return this;
	};
})(jQuery);
