(function($){
	
	var inter;
	var pause;
	var interLoading;

	$.fn.diaporama = function(options) {

		var defaults = {
			delay: 5,
			animationSpeed: "normal",
			controls:true,
			debut:"null"
		};
		
		var options = $.extend(defaults, options);
		
		$.fn.diaporama.stop = function(){
			clearInterval(inter);
			clearInterval(interLoading);
		}
		
		this.each(function(){
			var obj = $(this);
			// On va exécuter la fonction nextElt à chaque intervalle de temps
			inter = setInterval(function(){nextElt(options)}, (options.delay*1000));
			interLoading = setInterval(function(){nextImageLoad()}, (options.delay*250));
			// On teste si il y a plus d'une image, sinon le diaporama n'est pas nécessaire
			if($(obj).find("li").length > 1){
				// On enregistre le sens de rotation
				var sens = "right";
				// Par défaut, le diaporama n'est pas en pause
				if (pause){
					clearInterval(inter);
					clearInterval(interLoading);
				}
				else
					pause = false;
				// On cache tous les éléments de la liste
				$(obj).find("li").hide();
				// Le premier élément s'affiche progressivement et se voit attribuer la classe "active"
				if (options.debut == "null"){
					$(obj).find("li:first-child").addClass("active").fadeIn(options.animationSpeed);
				}else{
					$("#"+options.debut).addClass("active").fadeIn(options.animationSpeed);
					$("#selector a[name='"+options.debut+"']").addClass('activeSlide');
				}
				
				// 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).after("<div class='diaporama_controls'><div class='btns'><a href='#' class='pause'>Pause</a></div></div>");
					$(".diaporama_controls").html("<div class='btns'><a href='#' class='pause'></a></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);
							clearInterval(interLoading);
							pause = true;
						},
						function(){
							$(this).removeClass("play").addClass("pause");
							inter = setInterval(function(){ (sens == "right")?nextElt(options):prevElt(options)}, (options.delay*1000));
							interLoading = setInterval(function(){nextImageLoad()}, (options.delay*250));
							pause = false;
						}
					);
				}
				
				// fonction qui permet de passer à l’image suivante:
				function nextElt(options)
				{
					$(obj).find("li.active").fadeOut(options.animationSpeed);
					
					// Si l'image active courante n'est pas la dernière image de la liste
					if(!$(obj).find("li.active").is(":last-child"))
					{
						$("#selector").find("a.activeSlide").next().addClass("activeSlide").prev().removeClass("activeSlide");
						$(obj).find("li.active").next().addClass("active").prev().removeClass("active");
						// On affiche la nouvelle image active progressivement
						$(obj).find("li.active").fadeIn(options.animationSpeed);
						
					}
					else// L'image est la dernière de la liste
					{
						$("#selector").find("a:first-child").addClass("activeSlide");
						$("#selector").find("a:last-child").removeClass("activeSlide");
						$(obj).find("li:first-child").addClass("active").fadeIn(options.animationSpeed);
						$(obj).find("li:last-child").removeClass("active");
					}
				}
				
				//function pour faire tourner les images de londing
				function nextImageLoad(){
					if(!$("#loading").find("div.loadVert").is(":last-child"))
					{
						$("#loading").find("div.loadVert").next().addClass("loadVert").fadeIn(options.animationSpeed).prev().removeClass("loadVert");
					}
					else// L'image est la dernière de la liste
					{
						$("#loading").find("div:first-child").addClass("loadVert").fadeIn(options.animationSpeed);
						$("#loading").find("div:last-child").removeClass("loadVert");
					}
				}
				
				// 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);