/* ------------------------------------------------------
----------------- JAVASCRIPT SLIDE SHOW -----------------
-------------------------------------------------------*/
function slideSwitch(switchSpeed) {
	$btnActive = $("#rotator_btns .active");
	$btnActive.removeClass('active');
	var $active = $('#rotator DIV.active');
	
	if ( $active.length == 0 ) $active = $('#slideshow DIV:last');
	
	var $next =  $active.next('DIV').length ? $active.next('DIV')
		   : $('#rotator DIV:first');
	
	/*
	var $sibs = $active.siblings();
	var rndNum = Math.floor(Math.random() * $sibs.length );
	var $next = $( $sibs[ rndNum ] );
	*/
	$active.addClass('last-active');
	$next.css({opacity: 0.0})
	.addClass('active')
	.animate({opacity: 1.0}, switchSpeed, function() {
	$active.removeClass('active last-active');
	for (var $i=0; $i<$('#rotator DIV').length; $i ++) {
		if ($('#rotator div:eq(' + $i + ')').hasClass("active")){
			$('#rotator_btns a:eq(' + $i + ')').addClass("active");
		}
	}
	});
}

var $int=setInterval ("slideSwitch(1000)", 5000 );


function slideSelect(slideNum) {
clearInterval($int);
$btnActive = $("#rotator_btns .active");
$btnActive.removeClass('active');
var $selNum = slideNum - 1;
if (!($('#rotator div:eq(' + $selNum + ')').hasClass("active"))) {
	var $next = $('#rotator div:eq(' + $selNum + ')');
	var $active = $("#rotator .active");
	$active.addClass('last-active');
		$next.css({opacity: 0.0})
		.addClass('active')
		.animate({opacity: 1.0}, 1000, function() {
		$active.removeClass('active last-active');
		for (var $i=0; $i<$('#rotator DIV').length; $i ++) {
			if ($('#rotator div:eq(' + $i + ')').hasClass("active")){
				$('#rotator_btns a:eq(' + $i + ')').addClass("active");
			}
		}
		});
	}
}

/* -----------------------------------------------------
---------------- DROP DOWN NAVIGATION ------------------
-------------------------------------------------------*/
function startList()
{   
    //if (document.all&&document.getElementById)
    //{
	    navRoot = document.getElementById("nav");
        //crawlLIs(navRoot);
        
        navRootLIs = navRoot.getElementsByTagName("li");
        //alert(navRootLIs.length);
        
        for (var k=0; k<navRootLIs.length; k++)
        {
            navRootLIs[k].className += " out";
            makeDropDown(navRootLIs[k]);
            //alert(navRootLIs[k].className);
        }
        
        //breadcrumb = document.getElementById("breadcrumb");
        //breadcrumb.className="out";
        //alert(breadcrumb.className);
    //}
}

function makeDropDown(node)
{
    node.onmouseover=function()
    {
        //alert("pre-over [" + this.className + "]");
        this.className=this.className.replace(" out", "");
        this.className=this.className.replace("out", "");
        this.className+=" over";
        //alert("over [" + this.className + "]");
    }
    node.onmouseout=function()
    {
        //alert("pre-out [" + this.className + "]");
        this.className=this.className.replace(" over", "");
        this.className=this.className.replace("over", "");
        this.className+=" out";
        //alert("out [" + this.className + "]");
    }
}

function retract(node)
{
    //node.className=node.className.replace(" over", "");
    //node.className+=" out";
    //alert("!");
}

function crawlLIs(myUL)
{
    //alert(myUL.childNodes.length);
    for (var i=0; i<myUL.childNodes.length; i++)
    {
        node = myUL.childNodes[i];
        //alert(i + " / " + node.nodeName);
        if (node.nodeName=="LI")
        {
            //alert('encountered li:'+i);
            makeDropDown(node);
            //alert('getnavchildren:'+i);
            getNavChildren(node);
            retract(node);
        }
        //alert("!");
    }
}

function getNavChildren(myLI)
{
    //alert("#" + myLI.childNodes.length + "#");
    for (var j=0;j<myLI.childNodes.length;j++)
    {
        //alert(j + " / " + node.nodeName);
        node = myLI.childNodes[j];
        if (node.nodeName=="UL")
        {
            crawlLIs(node);
        }
        //alert(myLI.childNodes[i].innerHTML);
    }
}

function initRollovers() {
	if (!document.getElementById) return
	
	var aPreLoad = new Array();
	var sTempSrc;
	var aImages = document.getElementsByTagName('img');

	for (var i = 0; i < aImages.length; i++) {		
		if (aImages[i].className == 'imgover') {
			var src = aImages[i].getAttribute('src');
			var ftype = src.substring(src.lastIndexOf('.'), src.length);
			var hsrc = src.replace(ftype, '_o'+ftype);

			aImages[i].setAttribute('hsrc', hsrc);
			
			aPreLoad[i] = new Image();
			aPreLoad[i].src = hsrc;
			
			aImages[i].onmouseover = function() {
				sTempSrc = this.getAttribute('src');
				this.setAttribute('src', this.getAttribute('hsrc'));
			}	
			
			aImages[i].onmouseout = function() {
				if (!sTempSrc) sTempSrc = this.getAttribute('src').replace('_o'+ftype, ftype);
				this.setAttribute('src', sTempSrc);
			}
		}
	}
}

/* ----------------------------------------------------------------------
------------------------- TOOL TIPS DHTML -------------------------------
------------------------------------------------------------------------*/

var dw_event = {
  add: function(obj, etype, fp, cap) {
    cap = cap || false;
    if (obj.addEventListener) obj.addEventListener(etype, fp, cap);
    else if (obj.attachEvent) obj.attachEvent("on" + etype, fp);
  }, 
  remove: function(obj, etype, fp, cap) {
    cap = cap || false;
    if (obj.removeEventListener) obj.removeEventListener(etype, fp, cap);
    else if (obj.detachEvent) obj.detachEvent("on" + etype, fp);
  }, 
  DOMit: function(e) { 
    e = e? e: window.event;
    e.tgt = e.srcElement? e.srcElement: e.target;   
    if (!e.preventDefault) e.preventDefault = function () { return false; }
    if (!e.stopPropagation) e.stopPropagation = function () { if (window.event) window.event.cancelBubble = true; }      
    return e;
  }
}

var viewport = {
  getWinWidth: function () {
    this.width = 0;
    if (window.innerWidth) this.width = window.innerWidth - 18;
    else if (document.documentElement && document.documentElement.clientWidth) 
  		this.width = document.documentElement.clientWidth;
    else if (document.body && document.body.clientWidth) 
  		this.width = document.body.clientWidth;
  },
  
  getWinHeight: function () {
    this.height = 0;
    if (window.innerHeight) this.height = window.innerHeight - 18;
  	else if (document.documentElement && document.documentElement.clientHeight) 
  		this.height = document.documentElement.clientHeight;
  	else if (document.body && document.body.clientHeight) 
  		this.height = document.body.clientHeight;
  },
  
  getScrollX: function () {
    this.scrollX = 0;
  	if (typeof window.pageXOffset == "number") this.scrollX = window.pageXOffset;
  	else if (document.documentElement && document.documentElement.scrollLeft)
  		this.scrollX = document.documentElement.scrollLeft;
  	else if (document.body && document.body.scrollLeft) 
  		this.scrollX = document.body.scrollLeft; 
  	else if (window.scrollX) this.scrollX = window.scrollX;
  },
  
  getScrollY: function () {
    this.scrollY = 0;    
    if (typeof window.pageYOffset == "number") this.scrollY = window.pageYOffset;
    else if (document.documentElement && document.documentElement.scrollTop)
  		this.scrollY = document.documentElement.scrollTop;
  	else if (document.body && document.body.scrollTop) 
  		this.scrollY = document.body.scrollTop; 
  	else if (window.scrollY) this.scrollY = window.scrollY;
  },
  
  getAll: function () {
    this.getWinWidth(); this.getWinHeight();
    this.getScrollX();  this.getScrollY();
  }
  
}

var Tooltip = {
    followMouse: true,
    offX: 8,
    offY: 12,
    tipID: "tipDiv",
    showDelay: 100,
    hideDelay: 200,
    
    ready:false, timer:null, tip:null, 
  
    init: function() {  
        if ( document.createElement && document.body && typeof document.body.appendChild != "undefined" ) {
            if ( !document.getElementById(this.tipID) ) {
                var el = document.createElement("DIV");
                el.id = this.tipID; document.body.appendChild(el);
            }
            this.ready = true;
        }
    },
    
    show: function(e, msg) {
        if (this.timer) { clearTimeout(this.timer);	this.timer = 0; }
        this.tip = document.getElementById( this.tipID );
        if (this.followMouse) // set up mousemove 
            dw_event.add( document, "mousemove", this.trackMouse, true );
        this.writeTip("");  // for mac ie
        this.writeTip(msg);
        viewport.getAll();
        this.positionTip(e);
        this.timer = setTimeout("Tooltip.toggleVis('" + this.tipID + "', 'visible')", this.showDelay);
    },
    
    writeTip: function(msg) {
        if ( this.tip && typeof this.tip.innerHTML != "undefined" ) this.tip.innerHTML = msg;
    },
    
    positionTip: function(e) {
        if ( this.tip && this.tip.style ) {
            // put e.pageX/Y first! (for Safari)
            var x = e.pageX? e.pageX: e.clientX + viewport.scrollX;
            var y = e.pageY? e.pageY: e.clientY + viewport.scrollY;
    
            if ( x + this.tip.offsetWidth + this.offX > viewport.width + viewport.scrollX ) {
                x = x - this.tip.offsetWidth - this.offX;
                if ( x < 0 ) x = 0;
            } else x = x + this.offX;
        
            if ( y + this.tip.offsetHeight + this.offY > viewport.height + viewport.scrollY ) {
                y = y - this.tip.offsetHeight - this.offY;
                if ( y < viewport.scrollY ) y = viewport.height + viewport.scrollY - this.tip.offsetHeight;
            } else y = y + this.offY;
            
            this.tip.style.left = x + "px"; this.tip.style.top = y + "px";
        }
    },
    
    hide: function() {
        if (this.timer) { clearTimeout(this.timer);	this.timer = 0; }
        this.timer = setTimeout("Tooltip.toggleVis('" + this.tipID + "', 'hidden')", this.hideDelay);
        if (this.followMouse) // release mousemove
            dw_event.remove( document, "mousemove", this.trackMouse, true );
        this.tip = null; 
    },

    toggleVis: function(id, vis) { // to check for el, prevent (rare) errors
        var el = document.getElementById(id);
        if (el) el.style.visibility = vis;
    },
    
    trackMouse: function(e) {
    	e = dw_event.DOMit(e);
     	Tooltip.positionTip(e);
    }
    
}

function EmailLink(){
window.location = "mailto:"+"?subject=I thought this link might interest you." + "&body= "+window.location;
}

/* ---------------------------------------------------------------------*/
/* ---------------------------------------------------------------------*/


function windowLoad() {
	slideSwitch();
	//initRollovers();
	//startList();
	//Tooltip.init();
}

window.onload = windowLoad;