/*

Better(?) Image cross fader (C)2004 Patrick H. Lauke aka redux

Inspired by Steve at Slayeroffice http://slayeroffice.com/code/imageCrossFade/

preInit "Scheduler" idea by Cameron Adams aka The Man in Blue
http://www.themaninblue.com/writing/perspective/2004/09/29/

Tweaked to deal with empty nodes 19 Feb 2006

*/

/* general variables */

var gallery_aId = 'home_a'; /* change this to the ID of the gallery_a list */
var	gallery_a; /* this will be the object reference to the list later on */
var gallery_aImages; /* array that will hold all child elements of the list */
var currentImage_a; /* keeps track of which image should currently be showing */
var previousImage_a;
var preInitTimer_a;
preInit_a();

/* functions */

function preInit_a() {
	/* an inspired kludge that - in most cases - manages to initially hide the image gallery_a list
	   before even onload is triggered (at which point it's normally too late, and the whole list already
	   appeared to the user before being remolded) */
	if ((document.getElementById)&&(gallery_a=document.getElementById(gallery_aId))) {
		gallery_a.style.visibility = "hidden";
		if (typeof preInitTimer_a != 'undefined') clearTimeout(preInitTimer_a); /* thanks to Steve Clay http://mrclay.org/ for this small Opera fix */
	} else {
		preInitTimer_a = setTimeout("preInit_a()",2);
	}
}

function fader_a(imageNumber,opacity) {
	/* helper function to deal specifically with images and the cross-browser differences in opacity handling */
	var obj=gallery_aImages[imageNumber];
	if (obj.style) {
		if (obj.style.MozOpacity!=null) {
			/* Mozilla's pre-CSS3 proprietary rule */
			obj.style.MozOpacity = (opacity/100) - .001;
		} else if (obj.style.opacity!=null) {
			/* CSS3 compatible */
			obj.style.opacity = (opacity/100) - .001;
		} else if (obj.style.filter!=null) {
			/* IE's proprietary filter */
			obj.style.filter = "alpha(opacity="+opacity+")";
		}
	}
}

function fadeInit() {
	if (document.getElementById) {
		preInit_a(); /* shouldn't be necessary, but IE can sometimes get ahead of itself and trigger fadeInit first */
		gallery_aImages = new Array;
		var node = gallery_a.firstChild;
		/* instead of using childNodes (which also gets empty nodes and messes up the script later)
		we do it the old-fashioned way and loop through the first child and its siblings */
		while (node) {
			if (node.nodeType==1) {
				gallery_aImages.push(node);
			}
			node = node.nextSibling;
		}
		for(i=0;i<gallery_aImages.length;i++) {
			/* loop through all these child nodes and set up their styles */
			gallery_aImages[i].style.position='absolute';
//			gallery_aImages[i].style.top=0;
			gallery_aImages[i].style.zIndex=0;
			/* set their opacity to transparent */
			fader_a(i,0);
		}
		/* make the list visible again */
		gallery_a.style.visibility = 'visible';
		/* initialise a few parameters to get the cycle going */
		currentImage_a=0;
		previousImage_a=gallery_aImages.length-1;
		opacity=100;
		fader_a(currentImage_a,100);
		/* start the whole crossfade process after a second's pause */
		window.setTimeout("crossfade_a(100)", 3000);                              // Gary - time before first fade
	}
}

function crossfade_a(opacity) {
		if (opacity < 100) {
			/* current image not faded up fully yet...so increase its opacity */
			fader_a(currentImage_a,opacity);
			/* fader_a(previousImage_a,100-opacity); */
			opacity += 10;
			window.setTimeout("crossfade_a("+opacity+")", 60);
		} else {
			/* make the previous image - which is now covered by the current one fully - transparent */
			fader_a(previousImage_a,0);
			/* current image is now previous image, as we advance in the list of images */
			previousImage_a=currentImage_a;
			currentImage_a+=1;
			if (currentImage_a>=gallery_aImages.length) {
				/* start over from first image if we cycled through all images in the list */
				currentImage_a=0;
			}
			/* make sure the current image is on top of the previous one */
			gallery_aImages[previousImage_a].style.zIndex = 0;
			gallery_aImages[currentImage_a].style.zIndex = 100;
			/* and start the crossfade after a second's pause */
			opacity=0;
			window.setTimeout("crossfade_a("+opacity+")", 3200);                  // Gary - Time between fades
		}

}

/* initialise fader by hiding image object first */
addEvent(window,'load',fadeInit)



/* 3rd party helper functions */

/* addEvent handler for IE and other browsers */
function addEvent(elm, evType, fn, useCapture)
// addEvent and removeEvent
// cross-browser event handling for IE5+,  NS6 and Mozilla
// By Scott Andrew
{
 if (elm.addEventListener){
   elm.addEventListener(evType, fn, useCapture);
   return true;
 } else if (elm.attachEvent){
   var r = elm.attachEvent("on"+evType, fn);
   return r;
 }
}
