if (window != top) {
	top.location.href=location.href;
}

function exportToExcel() {
var oExcel = new ActiveXObject("Excel.Application");
var oBook = oExcel.Workbooks.Add;
var oSheet = oBook.Worksheets(1);
detailsTable=document.getElementById('rendered_table');
for (var y=0;y<detailsTable.rows.length;y++) {
// detailsTable is the table where the content to be exported is
	for (var x=0;x<detailsTable.rows(y).cells.length;x++) {
		oSheet.Cells(y+1,x+1) = detailsTable.rows(y).cells(x).innerText;
	}
}
	oSheet.Columns.autofit;
	oSheet.PageSetup.PrintTitleRows=oSheet.Rows(1).Address;
	oSheet.PageSetup.Zoom=false;
	oSheet.PageSetup.FitToPagesWide=1;
	oSheet.PageSetup.FitToPagesTall=1000;
	oSheet.PageSetup.PrintGridlines = true;
	oSheet.PageSetup.Orientation = 2;
	oExcel.Visible = true;
	oExcel.UserControl = true;
	oSheet.Rows(1).Font.Bold = true;
}

/**
 * This array is used to remember mark status of rows in browse mode
 */
var marked_row = new Array;
function setPointer(theRow, theRowNum, theAction, theDefaultColor, thePointerColor, theMarkColor)
{
    var theCells = null;

    // 1. Pointer and mark feature are disabled or the browser can't get the
    //    row -> exits
    if ((thePointerColor == '' && theMarkColor == '')
        || typeof(theRow.style) == 'undefined') {
        return false;
    }

    // 2. Gets the current row and exits if the browser can't get it
    if (typeof(document.getElementsByTagName) != 'undefined') {
        theCells = theRow.getElementsByTagName('td');
    }
    else if (typeof(theRow.cells) != 'undefined') {
        theCells = theRow.cells;
    }
    else {
        return false;
    }

    // 3. Gets the current color...
    var rowCellsCnt  = theCells.length;
    var domDetect    = null;
    var currentColor = null;
    var newColor     = null;
    // 3.1 ... with DOM compatible browsers except Opera that does not return
    //         valid values with "getAttribute"
    if (typeof(window.opera) == 'undefined'
        && typeof(theCells[0].getAttribute) != 'undefined') {
        currentColor = theCells[0].getAttribute('bgcolor');
        domDetect    = true;
    }
    // 3.2 ... with other browsers
    else {
        currentColor = theCells[0].style.backgroundColor;
        domDetect    = false;
    } // end 3

    // 3.3 ... Opera changes colors set via HTML to rgb(r,g,b) format so fix it
    if (currentColor.indexOf("rgb") >= 0) 
    {
        var rgbStr = currentColor.slice(currentColor.indexOf('(') + 1,
                                     currentColor.indexOf(')'));
        var rgbValues = rgbStr.split(",");
        currentColor = "#";
        var hexChars = "0123456789ABCDEF";
        for (var i = 0; i < 3; i++)
        {
            var v = rgbValues[i].valueOf();
            currentColor += hexChars.charAt(v/16) + hexChars.charAt(v%16);
        }
    }

    // 4. Defines the new color
    // 4.1 Current color is the default one
    if (currentColor == ''
        || currentColor.toLowerCase() == theDefaultColor.toLowerCase()) {
        if (theAction == 'over' && thePointerColor != '') {
            newColor              = thePointerColor;
        }
        else if (theAction == 'click' && theMarkColor != '') {
            newColor              = theMarkColor;
            marked_row[theRowNum] = true;
            // Garvin: deactivated onclick marking of the checkbox because it's also executed
            // when an action (like edit/delete) on a single item is performed. Then the checkbox
            // would get deactived, even though we need it activated. Maybe there is a way
            // to detect if the row was clicked, and not an item therein...
            // document.getElementById('id_rows_to_delete' + theRowNum).checked = true;
        }
    }
    // 4.1.2 Current color is the pointer one
    else if (currentColor.toLowerCase() == thePointerColor.toLowerCase()
             && (typeof(marked_row[theRowNum]) == 'undefined' || !marked_row[theRowNum])) {
        if (theAction == 'out') {
            newColor              = theDefaultColor;
        }
        else if (theAction == 'click' && theMarkColor != '') {
            newColor              = theMarkColor;
            marked_row[theRowNum] = true;
            // document.getElementById('id_rows_to_delete' + theRowNum).checked = true;
        }
    }
    // 4.1.3 Current color is the marker one
    else if (currentColor.toLowerCase() == theMarkColor.toLowerCase()) {
        if (theAction == 'click') {
            newColor              = (thePointerColor != '')
                                  ? thePointerColor
                                  : theDefaultColor;
            marked_row[theRowNum] = (typeof(marked_row[theRowNum]) == 'undefined' || !marked_row[theRowNum])
                                  ? true
                                  : null;
            // document.getElementById('id_rows_to_delete' + theRowNum).checked = false;
        }
    } // end 4

    // 5. Sets the new color...
    if (newColor) {
        var c = null;
        // 5.1 ... with DOM compatible browsers except Opera
        if (domDetect) {
            for (c = 0; c < rowCellsCnt; c++) {
                theCells[c].setAttribute('bgcolor', newColor, 0);
            } // end for
        }
        // 5.2 ... with other browsers
        else {
            for (c = 0; c < rowCellsCnt; c++) {
                theCells[c].style.backgroundColor = newColor;
            }
        }
    } // end 5

    return true;
} // end of the 'setPointer()' function

function CheckNew(table_col,value) {
	if (value == -1) {
		var submitbutton = document.getElementById("content-submit-button");
		submitbutton.click();
	}

}

function doTabRename() {
	document.formTabRename.submit();
}

function doLogonFocus() {
    var pidField = document.getElementById("logon-pid");
    var passwordField = document.getElementById("logon-password");
    if ((pidField != null) && (passwordField != null)) {
    		if ((pidField.value == "") && (passwordField.value == "")) {
		    pidField.focus();
		}
    }
}

function doLogonWait() {
	var waitAnimation = document.getElementById("logon-wait-animation");
	var waitAnimationImage = document.getElementById("logon-wait-animation-img");
	var waitText = document.getElementById("logon-wait-text");
	var submitButton = document.getElementById("logon-submit-button");
	var logonPid = document.getElementById("logon-pid");
	var logonPassword = document.getElementById("logon-password");
	var alternateUsername = document.getElementById("logon-alternate-username");
	var alternatePassword = document.getElementById("logon-alternate-password");
	if ((waitAnimation != null) && (waitText != null) && (submitButton != null)) {
		waitAnimation.style.visibility = "visible";
		waitAnimationImage.style.visibility = "visible";
		waitText.style.display = "block";
		submitButton.style.display = "none";
		alternateUsername.value = logonPid.value;
		alternatePassword.value = logonPassword.value;
	}
}

function preventEnterKey(e) {
	if ((e != null) && (e.keyCode == 13)) {
		return false;
	}
}

function setMinimumFontSize() {
	var XDivElement = document.getElementById('font-size-check');
	if (XDivElement.offsetHeight < "11") {
		tags = new Array ('body');
		for (j = 0; j < tags.length; j ++) { 
			var getbody = document.getElementsByTagName(tags[j]).item(0); 
			if (getbody) {
				getbody.style.fontSize =  "11px";
				//alert(Math.abs(.7 * (11 - XDivElement.offsetHeight)) + 'em');
			}
		}
	}
}

function showmore (postid) { 

   whichpost = document.getElementById(postid); 
   
   if (whichpost.className=="postshown") { 
      whichpost.className="posthidden"; 
   } 
   else { 
      whichpost.className="postshown"; 
   } 
} 
/*
function ConfirmRemove(itemtype) {
	return false ;
}
*/
function doPageLoad() {
	doLogonFocus();
	setMinimumFontSize();
}

window.onload = doPageLoad;