

var speed = 40; // milliseconds between each step of transition
var steps = 20; // amount to + or - by each step of transition
var fadeToText = "ffffff"; // color for text to fade to
var fadeToCell = "161619"; // color for cell to fade to
var origText = "888888"; // original text color
var origCell = "1d1d20"; // original cell color
var newBorder = "27272a"; // border hover color
var origBorder = "27272a"; // original border color

dC21 = new Array(hextodec(origText.substring(0, 2)),hextodec(origText.substring(2, 4)),hextodec(origText.substring(4, 6)));
dC22 = new Array(hextodec(fadeToText.substring(0, 2)),hextodec(fadeToText.substring(2, 4)),hextodec(fadeToText.substring(4, 6)));


function makearray(n) {
  this.length = n;
  for(var i = 1; i <= n; i++)
    this[i] = 0;
  return this;
}
function hex(i) {
  if (i < 0)    return "00";
  else if (i > 255) return "ff";
  else      return "" + hexa[Math.floor(i/16)] + hexa[i%16];
}
function hexnumtodec(hexchar) {
  if (parseInt(hexchar) == hexchar) return Number(hexchar)
  hexchar = hexchar.toUpperCase()
  switch (hexchar) {
    case 'A': return 10; break;
    case 'B': return 11; break;
    case 'C': return 12; break;
    case 'D': return 13; break;
    case 'E': return 14; break;
    case 'F': return 15; break;
  }
}
function hextodec(daHex) {
  var daDec = Number((16 * hexnumtodec(daHex.substring(0,1))) + hexnumtodec(daHex.substring(1,2)))
  return daDec
}

function convert2Dec(hex)
  {
    var rgb = new Array();
    for (var u = 0; u < 3; u++)
      rgb[u] = parseInt(hex.substring(u*2, u*2+2), 16);
    return rgb;
  }

mode = true;

function setColor(r,g,b,what) {
  var hr = hex(r); var hg = hex(g); var hb = hex(b);
  var daColor = "#"+hr+hg+hb
  if(mode){
           daEl.style.backgroundColor = daColor;
           mode = false;
  }
  else{
          if(dC21[0] < dC22[0]) dC21[0] += step;
          if(dC21[0] > dC22[0]) dC21[0] -= step;
          if(dC21[1] < dC22[1]) dC21[1] += step;
          if(dC21[1] > dC22[1]) dC21[1] -= step;
          if(dC21[2] < dC22[2]) dC21[2] += step;
          if(dC21[2] > dC22[2]) dC21[2] -= step;
          dC2B = "RGB(" + dC21[0] + "," + dC21[1] + "," + dC21[2] + ")";
          daEl.style.color = dC2B;
          mode = true;
  }       
  if (daColor == colorend.toLowerCase()) {
    dC21[0] = hextodec(origText.substring(0, 2));
    dC21[1] = hextodec(origText.substring(2, 4));
    dC21[2] = hextodec(origText.substring(4, 6));
    dC2B = "RGB(" + dC22[0] + "," + dC22[1] + "," + dC22[2] + ")";
    daEl.style.color = dC2B;
    clearInterval(iId)
    iId = null
    timerRunning = false
    mode = true
  }
}

function fade(what) {
  i++
  setColor(
    Math.floor(sr * ((step-i)/step) + er * (i/step)),
    Math.floor(sg * ((step-i)/step) + eg * (i/step)),
    Math.floor(sb * ((step-i)/step) + eb * (i/step)),
    what);
}
hexa = new makearray(16);
for(var i = 0; i < 10; i++)
  hexa[i] = i;
hexa[10]="a"; hexa[11]="b"; hexa[12]="c";
hexa[13]="d"; hexa[14]="e"; hexa[15]="f";

var i
var iId = null
var sr, sg, sb
var er, eg, eb
var interval = 1
var step = 16
var colorstart
var colorend
var daEl
var timerRunning = false

function myfade(el,cs,ce,iv,st) {
  daEl = el
  colorstart = cs
  colorend = ce
  interval = iv
  step = st
  i = 0
  if (timerRunning) {
    clearInterval(iId)
    iId = null
  }
  var myRe = /#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})/i
  if (colorstart.match(myRe)) {
    sr = hextodec(RegExp.$1)
    sg = hextodec(RegExp.$2)
    sb = hextodec(RegExp.$3)
  }
  if (colorend.match(myRe)) {
    er = hextodec(RegExp.$1)
    eg = hextodec(RegExp.$2)
    eb = hextodec(RegExp.$3)
  }
  timerRunning = false;
  iId = setInterval("fade()",interval)
  timerRunning = true;
}
function orig(tc){
         dC21[0] = hextodec(origText.substring(0, 2));
         dC21[1] = hextodec(origText.substring(2, 4));
         dC21[2] = hextodec(origText.substring(4, 6));
         tc.style.backgroundColor = "#" + origCell;
         tc.style.borderColor = "#" + origBorder;
         tc.style.color = "#" + origText;
}
function cellover1(tc) {
  orig(tc);
  colorNow = "#" + origCell;
  colorTo = "#" + fadeToCell;
  myfade(tc,colorNow,colorTo,speed,steps)
  tc.style.borderColor = "#" + newBorder;
}
function cellout1(tc) {
  clearInterval(iId)
  tc.style.borderColor = "#" + origBorder;
  orig(tc);
}


  /*****************************************\
||       fade2 Script Version 4.0         ||
||   http://anarchos.xs.mw/fade2.phtml    ||
||            (c) July 2001              ||
|| _____________________________________ ||
|| Created by:                           ||
|| Anarchos    > anarchos.xs.mw          ||
|| _____________________________________ ||
|| auto-startColor by Mike West          ||
|| mike@westman.org                      ||
|| _____________________________________ ||
|| uniqueID upgrade by DubMatrix         ||
|| http://www.princefari.com             ||
|| _____________________________________ ||
|| Color conversion from decimal to      ||
|| hex (dehexize function) by:           ||
|| Litejet > litejet@hotmail.com         ||
|| _____________________________________ ||
|| fade2, hex, setColor functions by:     ||
|| Dak Phoenix > phoenix-archetypes.com  ||
|| _____________________________________ ||
|| domouseover/out based on scripts by   ||
|| The Shadow  > www.icon.co.za/~andrewk ||
||                                       ||
|| _____________________________________ ||
|| Netscape v4+ support added by         ||
|| tk102 > zxcvbnm6012@yahoo.com         ||
|| Mar 24, 2004                          ||
\*****************************************/




// This part is configurable
//------------------------------------------------
startColor = "#ffffff"; // MouseOut link color
endColor = "#ffa942"; // MouseOver link color
stepIn = 27; // delay when fading in
stepOut = 27; // delay when fading out
autofade2 = false;
sloppyClass = true;
//------------------------------------------------

hexa = new makearray2(16);
for(var i = 0; i < 10; i++)
hexa[i] = i;
hexa[10]="a"; hexa[11]="b"; hexa[12]="c";
hexa[13]="d"; hexa[14]="e"; hexa[15]="f";

var version = parseInt(navigator.appVersion)
var appName = navigator.appName
var ns4 = version>=4 && appName=="Netscape"

if (ns4) { //Netscape 4+
	document.onmouseover = doN4mouseover;
	document.onmouseout = doN4mouseout;
} else { //other
	document.onmouseover= domouseover;
	document.onmouseout= domouseout;
}

startColor = dehexize(startColor.toLowerCase());
endColor = dehexize(endColor.toLowerCase());
var fade2Id = new Array();

function dehexize(Color){
	var colorArr = new makearray2(3);
	for (i=1; i<7; i++){
		for (j=0; j<16; j++){
			if (Color.charAt(i) == hexa[j]){
				if (i%2 !=0)
					colorArr[Math.floor((i-1)/2)]=eval(j)*16;
				else
					colorArr[Math.floor((i-1)/2)]+=eval(j);
			}
		}
	}
	return colorArr;
}

function domouseover() {
	if(document.all){
		var srcElement = event.srcElement;
		if ((srcElement.tagName == "A" && autofade2) || srcElement.className == "fade2" || (sloppyClass && srcElement.className.indexOf("fade2") != -1))
			fade2(startColor,endColor,srcElement.uniqueID,stepIn);
	}
}

function domouseout() {
	if (document.all){
		var srcElement = event.srcElement;
		if ((srcElement.tagName == "A" && autofade2) || srcElement.className == "fade2" || (sloppyClass && srcElement.className.indexOf("fade2") != -1))
			fade2(endColor,startColor,srcElement.uniqueID,stepOut);
	}
}
function doN4mouseover(event) {
	var srcElement=event.target;
	if ((srcElement.tagName == "A" && autofade2) || srcElement.className == "fade2" || (sloppyClass && srcElement.className.indexOf("fade2") != -1))
		nfade2(startColor,endColor,srcElement,stepIn);
}

function doN4mouseout(event) {
		var srcElement = event.target; 
		if ((srcElement.tagName == "A" && autofade2) || srcElement.className == "fade2" || (sloppyClass && srcElement.className.indexOf("fade2") != -1))
		 nfade2(endColor,startColor,srcElement,stepOut);
}

function makearray2(n) {
	this.length = n;
	for(var i = 1; i <= n; i++)
	this[i] = 0;
	return this;
}

function hex(i) {
	if (i < 0)
		return "00";
	else if (i > 255)
		return "ff";
	else
		return "" + hexa[Math.floor(i/16)] + hexa[i%16];
}

function setColor2(r, g, b, element) {
	var hr = hex(r);
	var hg = hex(g);
	var hb = hex(b);
	element.style.color = "#"+hr+hg+hb;
}


function fade2(s,e, element,step){
	var sr = s[0];
	var sg = s[1];
	var sb = s[2];

	var er = e[0];
	var eg = e[1];
	var eb = e[2];

	if (fade2Id[0] != null && fade2[0] != element){  //check have we already fade2d this?
		setColor2(sr,sg,sb,eval(fade2Id[0]));   // no, set the first color
		var i = 1;
		while(i < fade2Id.length){             //get ready to fade2
			clearTimeout(fade2Id[i]);
			i++;
		}
	}
        //MSIE must setup timeouts using strings        
	for(var i = 0; i <= step; i++) { //timeouts fall like dominos
		fade2Id[i+1] = setTimeout("setColor2(Math.floor(" +sr+ " *(( " +step+ " - " +i+ " )/ " +step+ " ) + " +er+ " * (" +i+ "/" +
		step+ ")),Math.floor(" +sg+ " * (( " +step+ " - " +i+ " )/ " +step+ " ) + " +eg+ " * (" +i+ "/" +step+
		")),Math.floor(" +sb+ " * ((" +step+ "-" +i+ ")/" +step+ ") + " +eb+ " * (" +i+ "/" +step+ ")),"+element+");",i*step);
	}
	fade2Id[0] = element; // oneshot
}
function nfade2(s,e, element,step){ 
	var sr = s[0];
	var sg = s[1];
	var sb = s[2];

	var er = e[0];
	var eg = e[1];
	var eb = e[2];

	if (fade2Id[0] != null && fade2[0] != element){  //check have we already fade2d this?
		setColor2(sr,sg,sb,eval(fade2Id[0]));   // no, set the first color
		var i = 1;
		while(i < fade2Id.length){             //get ready to fade2
			clearTimeout(fade2Id[i]);
			i++;
		}
	}
        //Netscape can call SetTimeout using objects, making for more readable code
	for(var i = 0; i <= step; i++) { 
		fade2Id[i+1] = setTimeout(
					setColor2,
					i*step,
					Math.floor(sr*((step-i)/step) + er*(i/step)),
					Math.floor(sg*((step-i)/step) + eg*(i/step)),
					Math.floor(sb*((step-i)/step) + eb*(i/step)),
					element
					);
	}
	fade2Id[0] = element; //oneshot
}

///////////////////////////////////////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////////////////////////////////////////
function selectTab2(n) {
   // Rendre l'attribut z-index du nième onglet et panneau supérieur à celui des autres
   var panel2ID = "p2"
   var numDiv = 8
   // Itérer toutes les paires onglet/panneau
   for(var i=0; i < numDiv; i++) {
      var tabDiv = document.getElementById(panel2ID+"tab"+i)
      var panel2Div = window.document.getElementById(panel2ID+"panel"+i)
      z = panel2Div.style.zIndex
      // Si le clic porte sur cette paire et qu'elle ne figure pas à l'avant, la faire passer à l'avant
      if (z != numDiv && i == n) { z = numDiv }
      // Dans tous les autres cas, la laisser à sa position d'origine
      else { z = (numDiv-i) }
      panel2Div.style.zIndex = z;
   }
}
///////////////////////////////////////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////////////////////////////////////////
