// Products functionsfunction searchProducts(theFilter, theFilter2) {	var tempFilter = theFilter;//	if (theFilter.length <= 0 || theFilter == 'Search Products') tempFilter = theFilter2;	if (document.searchForm2 != undefined) {		document.searchForm.searchVal.value = tempFilter;	}	loadProducts("", tempFilter, "");}function loadProducts(theCategory, theFilter, theSort, theApp) {	if ($("#productView").length) {	//	"nav").getElementsByTagName("LI");//			this.className+=" sfhover";					$(".sfhover").removeClass( "sfhover" );		var formOptions = {};		formOptions.cid = theCategory;		formOptions.filter = theFilter;		formOptions.order = theSort;		if (theApp == undefined) theApp = "";		formOptions.app = theApp;		$.post(	"includes/productView.php",			formOptions,			function(data)			{				// sets the code for the rolodexdivinnercontainer				$("#productView").html(data);			}		);	}	else {		var tempQuery = "";		if (theCategory.length) {			if (tempQuery.length) tempQuery += "&";			tempQuery += "c=" + theCategory;		}		if (theFilter.length) {			if (tempQuery.length) tempQuery += "&";			tempQuery += "f=" + theFilter;		}		if (theSort.length) {			if (tempQuery.length) tempQuery += "&";			tempQuery += "s=" + theSort;		}		if (theApp != undefined && theApp.length) {			if (tempQuery.length) tempQuery += "&";			tempQuery += "a=" + theApp;		}		document.location = "products.php?" + tempQuery;	}}// JavaScript Documentfunction MM_preloadImages() { //v3.0  var d=document; if(d.images){ if(!d.MM_p) d.MM_p=new Array();    var i,j=d.MM_p.length,a=MM_preloadImages.arguments; for(i=0; i<a.length; i++)    if (a[i].indexOf("#")!=0){ d.MM_p[j]=new Image; d.MM_p[j++].src=a[i];}}}function MM_swapImgRestore() { //v3.0  var i,x,a=document.MM_sr; for(i=0;a&&i<a.length&&(x=a[i])&&x.oSrc;i++) x.src=x.oSrc;}function MM_findObj(n, d) { //v4.01  var p,i,x;  if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {    d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}  if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];  for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);  if(!x && d.getElementById) x=d.getElementById(n); return x;}function MM_swapImage() { //v3.0  var i,j=0,x,a=MM_swapImage.arguments; document.MM_sr=new Array; for(i=0;i<(a.length-2);i+=3)   if ((x=MM_findObj(a[i]))!=null){document.MM_sr[j++]=x; if(!x.oSrc) x.oSrc=x.src; x.src=a[i+2];}}sfHover = function() {	var sfEls = document.getElementById("nav").getElementsByTagName("LI");	for (var i=0; i<sfEls.length; i++) {		sfEls[i].onmouseover=function() {			this.className+=" sfhover";		}		sfEls[i].onmouseout=function() {			this.className=this.className.replace(new RegExp(" sfhover\\b"), "");		}	}}if (window.attachEvent) window.attachEvent("onload", sfHover);sfHover2 = function() {	var sfEls = document.getElementById("nav2").getElementsByTagName("LI");	for (var i=0; i<sfEls.length; i++) {		sfEls[i].onmouseover=function() {			this.className+=" sfhover2";		}		sfEls[i].onmouseout=function() {			this.className=this.className.replace(new RegExp(" sfhover2\\b"), "");		}	}}if (window.attachEvent) window.attachEvent("onload", sfHover2);// TABLE STRIPING (alternating rows of colors)// this function is needed to work around // a bug in IE related to element attributesfunction hasClass(obj) { var result = false; if (obj.getAttributeNode("class") != null) {     result = obj.getAttributeNode("class").value; } return result;}   function stripe(id) {// the flag we'll use to keep track of // whether the current row is odd or evenvar even = false;// if arguments are provided to specify the colours// of the even & odd rows, then use the them;// otherwise use the following defaults:var evenColor = arguments[1] ? arguments[1] : "#d7d7d7";var oddColor = arguments[2] ? arguments[2] : "#ebebeb";// obtain a reference to the desired table// if no such table exists, abortvar table = document.getElementById(id);if (! table) { return; }// by definition, tables can have more than one tbody// element, so we'll have to get the list of child// &lt;tbody&gt;s var tbodies = table.getElementsByTagName("tbody");// and iterate through them...for (var h = 0; h < tbodies.length; h++) { // find all the &lt;tr&gt; elements...   var trs = tbodies[h].getElementsByTagName("tr");    // ... and iterate through them  for (var i = 0; i < trs.length; i++) {    // avoid rows that have a class attribute    // or backgroundColor style    if (! hasClass(trs[i]) &&        ! trs[i].style.backgroundColor) {		        // get all the cells in this row...      var tds = trs[i].getElementsByTagName("td");          // and iterate through them...      for (var j = 0; j < tds.length; j++) {            var mytd = tds[j];        // avoid cells that have a class attribute        // or backgroundColor style        if (! hasClass(mytd) &&            ! mytd.style.backgroundColor) {              mytd.style.backgroundColor =            even ? evenColor : oddColor;                }      }    }    // flip from odd to even, or vice-versa    even =  ! even;  }}}// end TABLE STRIPING (alternating rows of colors)