var tabLinks = new Array();
var contentDivs = new Array();

function init() {

    // Grab the tab links and content divs from the page
    var tabListItems = document.getElementById('TCCtabs').childNodes;
    for ( var i = 0; i < tabListItems.length; i++ ) {
        if ( tabListItems[i].nodeName == "LI" ) {
	    var tabLink = getFirstChildWithTagName( tabListItems[i], 'A' );
	    var id = getHash( tabLink.getAttribute('href') );
	    tabLinks[id] = tabLink;
	    contentDivs[id] = document.getElementById( id );
        }
    }

    // Assign onclick events to the tab links, and
    // highlight the first tab
    var i = 0;

    for ( var id in tabLinks ) {
        tabLinks[id].onclick = showTab;
        tabLinks[id].onfocus = function() { this.blur() };
        if ( i == 0 ) tabLinks[id].className = 'selected';
        i++;
    }

    // Hide all content divs except the first
    var i = 0;

    for ( var id in contentDivs ) {
        if ( i != 0 ) contentDivs[id].className = 'TCCtabContent hide';
        i++;
    }
    // If a hash was supplied in the page URL,
    // display the corresponding tab (if found)
    if ( document.location.hash ) showTab( document.location.hash.substring(1) );
}

function showTab( selectedId ) {
    if ( typeof selectedId != 'string' ) var selectedId = getHash( this.getAttribute('href') );
    // Highlight the selected tab, and dim all others.
    // Also show the selected content div, and hide all others.
    for ( var id in contentDivs ) {
        if ( id == selectedId ) {
	    tabLinks[id].className = 'selected';
	    contentDivs[id].className = 'TCCtabContent';
        } else {
	    tabLinks[id].className = '';
	    contentDivs[id].className = 'TCCtabContent hide';
        }
    }

    // Stop the browser following the link
    return false;
}


function getFirstChildWithTagName( element, tagName ) {
    for ( var i = 0; i < element.childNodes.length; i++ ) {
        if ( element.childNodes[i].nodeName == tagName ) return element.childNodes[i];
    }
}


function getHash( url ) {
    var hashPos = url.lastIndexOf ( '#' );
    return url.substring( hashPos + 1 );
}