
// Variables globales
var activeImage = 3;
var staticImage = 3;
var maxImage = 12;
var thumbTimer = new Array();
var thumbImage = new Array();
var TimeToFade = 1000.0; 

// Enregistrer le compteur
function startThumbnail()
{
	// Attribution des sources en court
	var thumbSource = getImage();
	thumbSource.sort(sortNumber);
	
	// Définition du tableau des sources disponibles
	pickImg = new Array();
	for(var i=0, k=0, j=0; i<maxImage; i++)
	{
		if(thumbSource[k] != (i + 1))
		{			
			pickImg[j] = (i + 1);
			j++;
		}
		else
			k++;
	}
	
	// Définition des trois images aléatoires suivantes
	thumbImage = getUnique(3, pickImg.length);
	var str = "0";		
	for(var i=0; i<thumbImage.length; i++)		
		thumbImage[i] = "images/thumbnail/" + str.repeat(3 - pickImg[thumbImage[i] - 1].toString().length) + pickImg[thumbImage[i] - 1] + ".jpg";
	
	// Démarrer un timer aléatoire pour les images statiques
	for(var i=0; i<staticImage; i++)
		thumbTimer[i] = setTimeout("fade('img_thumb_00" + (i + 1) + "', true)", getRandom(6000, 8000) + (1500 * (i + 1)));		
}

function getImage()
{
	var thumbSource = new Array();
	
	for(var i=0; i<staticImage; i++)
	{
		var tmp = document.getElementById("img_thumb_00" + (i + 1)).src;
		thumbSource.push(parseInt(tmp.substr(tmp.lastIndexOf(".") - 3, 3), 10));
	}
	
	return thumbSource;
}

function animateThumbnail(id)
{
	// Élément à faire disparaitre
	var element = document.getElementById(id);	

	// Trouver une case vide
	var thumb = new Array();
	thumb = getThumbnail();	
	var empty = document.getElementById(thumb[getRandom(0, (thumb.length - 1))]);
	element.parentNode.innerHTML = "&nbsp;";
	
	// Vider la case
	removeAllChild(empty);
	
	// Copier l'image précédente
	empty.appendChild(element);
	
	// Changer son image
	element.src = thumbImage[id.substr(12) - 1];
	
	// Animation de fadein
	fade(id, false);
	
	// Activer de nouveau le compteur
	if((id.substr(12) - 1) == 2)
		startThumbnail();
}

function getThumbnail()
{
	// Nouveau tableau
	var thumb = new Array();
	
	// Navigation dans les carrés
	for(var i=0; i<5; i++)
	{
		if(document.getElementById('thumb_00' + (i + 1)).innerHTML == "&nbsp;")
			thumb.push('thumb_00' + (i + 1));
	}
	
	// Renvoyer le tableau
	return thumb;
}

function fade(eid, launch)
{
	var element = document.getElementById(eid);
	if(element == null)
		return;

	if(element.FadeState == null)
	{
		if(element.style.opacity == null 
		|| element.style.opacity == '' 
		|| element.style.opacity == '1')
		{
			element.FadeState = 2;
		}
		else
		{
			element.FadeState = -2;
		}
	}

	if(element.FadeState == 1 || element.FadeState == -1)
	{
		element.FadeState = element.FadeState == 1 ? -1 : 1;
		element.FadeTimeLeft = TimeToFade - element.FadeTimeLeft;
	}
	else
	{
		element.FadeState = element.FadeState == 2 ? -1 : 1;
		element.FadeTimeLeft = TimeToFade;
		setTimeout("animateFade(" + new Date().getTime() + ",'" + eid + "'," + launch + ")", 33);
	}  
}

function animateFade(lastTick, eid, launch)
{  			
	var curTick = new Date().getTime();
	var elapsedTicks = curTick - lastTick;

	var element = document.getElementById(eid);

	if(element.FadeTimeLeft <= elapsedTicks)
	{
		element.style.opacity = element.FadeState == 1 ? '1' : '0';
		element.style.filter = 'alpha(opacity = ' 
		+ (element.FadeState == 1 ? '100' : '0') + ')';
		element.FadeState = element.FadeState == 1 ? 2 : -2;
		
		// Terminer le fade
		if(launch)
			animateThumbnail(eid);
			
		return;
	}

	element.FadeTimeLeft -= elapsedTicks;
	var newOpVal = element.FadeTimeLeft/TimeToFade;
	if(element.FadeState == 1)
		newOpVal = 1 - newOpVal;

	element.style.opacity = newOpVal;
	element.style.filter = 'alpha(opacity = ' + (newOpVal * 100) + ')';

	setTimeout("animateFade(" + curTick + ",'" + eid + "', " + launch + ")", 33);
}
