// Rollover  v1.0
// http://www.dithered.com/javascript/rollover/index.html
// code by Chris Nott (chris@NOSPAMdithered.com - remove NOSPAM)

// modified by Steve Bond (sbond@NOJUNKMAILblastradius.com - remove NOJUNKMAIL) to allow third set of images, for selected state.

var rolloverImageOff = new Array();
var rolloverImageOn = new Array();
var rolloverImageSel = new Array();
var rolloverCurrent = '';


// Preload rollover images
function rolloverInit() {
	if (document.images) {
		
		// for each rollover, preload both states and put filename in an associative array
		for (var i = 0; i < rolloverImageOnFiles.length; i++) {
			rolloverCurrentName = rolloverImageTagNames[i];

			rolloverImageOff[rolloverCurrentName] = new Image();
			rolloverImageOn[rolloverCurrentName] = new Image();
			rolloverImageSel[rolloverCurrentName] = new Image();
			rolloverImageOff[rolloverCurrentName].src = rolloverImageDirectory + rolloverImageOffFiles[i];
			rolloverImageOn[rolloverCurrentName].src = rolloverImageDirectory + rolloverImageOnFiles[i];
			rolloverImageSel[rolloverCurrentName].src = rolloverImageDirectory + rolloverImageSelFiles[i];
		}
	}
}


// On state activation
function rolloverOn(img, layer) {
	if (img == rolloverCurrent) return false;
	if (document.images && rolloverImageOn[img]) {
		
		// rollovers in layers in NS4 require a different image reference
		if (layer != null && document.layers) {
			if (typeof(layer) == 'object') layer.document.images[img].src = rolloverImageOn[img].src;
			else if (typeof(layer) == 'string') eval('document.layers["' + layer + '"].document.images[img].src = rolloverImageOn[img].src');
		}
		
		// non-layer rollovers in NS4 and all rollovers in other browsers
		else if (document.images[img]) document.images[img].src = rolloverImageOn[img].src;
	}
}


// Off state activation
function rolloverOff(img, layer) {
	if (img == rolloverCurrent) return false;
	if (document.images && rolloverImageOff[img]) {

		// rollovers in layers in NS4 require a different image reference
		if (layer != null && document.layers) {
			if (typeof(layer) == 'object') layer.document.images[img].src = rolloverImageOff[img].src;
			else if (typeof(layer) == 'string') eval('document.layers["' + layer + '"].document.images[img].src = rolloverImageOff[img].src');
		}
		
		// non-layer rollovers in NS4 and all rollovers in other browsers
		else if (document.images[img]) document.images[img].src = rolloverImageOff[img].src;
	}
}

// Selected state activation
function rolloverSel(img, layer) {
	if (document.images && rolloverImageSel[img]) {

		// rollovers in layers in NS4 require a different image reference
		if (layer != null && document.layers) {
			if (typeof(layer) == 'object') layer.document.images[img].src = rolloverImageSel[img].src;
			else if (typeof(layer) == 'string') eval('document.layers["' + layer + '"].document.images[img].src = rolloverImageSel[img].src');
		}
		
		// non-layer rollovers in NS4 and all rollovers in other browsers
		else if (document.images[img]) document.images[img].src = rolloverImageSel[img].src;
	}
}


// Rollover with state function (not used in standard rollovers; included for flexability)
function rolloverSetCurrent(img) {
	if (rolloverCurrent) var tmgImg = rolloverCurrent;
	rolloverCurrent = img;
	if (tmgImg) rolloverOff(tmgImg);
	rolloverSel(rolloverCurrent);
}

// called here instead of in "body onlosd" event
rolloverInit();

