var panel;
var wait;
var dialog;
var oMenu;
var mX;
var mY;
var tip;
var isIE = document.all?true:false;
var intervalID = false;
var slider;
var gen;
var cam;
var tt;
var addUpgrades = false;
var tabView;
var rTabView;
var stopMessage = false;
var thumber;
var totalCams=0;
document.onmousemove = getMouseXY;

var timer;
var timedout = false;

var con = null;

function gotoskin(){
	
	
	window.location = "/"+document.getElementById('siteMenuDD').value;

}

function _checkBillHeight(div){

	if(parseInt(document.getElementById(div).offsetHeight) > 400){
		
		document.getElementById(div).style.height = "400px";
		document.getElementById(div).style.overflowY = "scroll";
		
	}

}

function calc(){

	document.getElementById('calc').value = 1;
	document.getElementById('calcForm').submit();

}

function handleAdvSubmit(){

	
	var callback = {
   success : function(o) {
		
		dialog.hide();
		
   }
		
   }
	YAHOO.util.Connect.setForm('advFrm');
	var conn = YAHOO.util.Connect.asyncRequest("POST", "?updateAdv=true", callback);

}

function advanced(str){
	
	var callback = {
   success : function(o) {
	   	
		var response = eval("(" + o.responseText + ")");
		 
		var title = response['title']; 
		
			// show dialog
			if(dialog)
			dialog.destroy();

		dialog = new YAHOO.widget.Dialog("save", 
		{ 
			width:"600px",
	   	 visible:true,  
	   	 draggable:true,
	   	 fixedcenter: true,
	  	  constraintoviewport:true,
	  	  buttons : [ { text:"Submit", handler:handleAdvSubmit, isDefault:true }, { text:"Cancel", handler:handleCancel } ]
		} 
); 

		var data = response['data'];
	
		dialog.setHeader(title+' Advanced Options');
		dialog.setBody('<div style="text-align:left"><form action="?save" name="advFrm" method="post"><span style="color:#FF0000">WARNING</span><br/>Changing these settings can alter the server recommendations and SPI results significantly. If the wrong settings are selected here then the results from the Iomnis calculator will be incorrect; please leave them as defaults to prevent the risk of suggesting the wrong server to your client.<br/><br/>'+data+'</form></div>');
		dialog.render(document.body);
		
			
        }
	}

	// Connect to our data source and load the data
	
	YAHOO.util.Connect.setForm('calcForm');
	var conn = YAHOO.util.Connect.asyncRequest("POST", "?getAdvanced="+str, callback);

}

function loadFlash(){
	if(document.getElementById('mainDiv')){
		if(DetectFlashVer('8','0','0')){
			var r = 400/1166;
			var mr = 267/400;
			var newWidth = (document.getElementById('mainDiv').offsetWidth*1)*r;
			var newHeight = newWidth*mr;
			var d = document.getElementById('preview');
			d.innerHTML = '';
			createFlash('preview','/video/test.swf',newWidth,newHeight,false,''); //end AC code
		} else {
			
			var d = document.getElementById('preview');
			d.innerHTML = '<a href="http://www.adobe.com/go/EN_US-H-GET-FLASH" target="_blank"><img src="http://www.adobe.com/images/shared/download_buttons/get_adobe_flash_player.png" alt=""/></a>';	
				
		}
	}
}

function help(url){


	var callback =
	{
 	 success:helpSuccess,
 	 failure: handleFailure
	};
	
	var request = YAHOO.util.Connect.asyncRequest('POST', url, callback);

}

function helpSuccess(o){

		var h = document.body.clientHeight+"px";
		var h2 = (document.body.clientHeight-25)+"px";

		panel = new YAHOO.widget.Panel("message", 
		{ 
			width:"500px",
			close:true,  
			visible:true,  
			draggable:true,
			fixedcenter: false,
			constraintoviewport:true,
			height:h
	
		} 
		); 
		panel.setHeader('Help');
		panel.setBody('<div style="height:'+h2+'">'+o.responseText+'</div>');
		panel.render(document.body);

}

function checkMessages(){
	// check for messages
	var callback = {
   success : function(o) {
		response = eval("("+o.responseText+")");
		if(response['msg'])
               		 fadeMessagePanel(response['type'],response['msg']);
		
		if(response['error']){
			setTimeout('checkMessages()',3000);
		}
            },	
	failure: function(){

			setTimeout('checkMessages()',3000);

		}
	}

	// Connect to our data source and load the data
	if(!stopMessage)
        	var conn = YAHOO.util.Connect.asyncRequest("GET", "http://portal.iomnis.com/messages?skin=newCSC&getMessages=", callback);

	
	}
checkMessages();

function errorPanel(str){

	if(panel)
		panel.hide();

	panel = new YAHOO.widget.Panel("error", 
	{ 
		width:"450px",
	    close:true,  
	    visible:true,  
	    draggable:false,
	    fixedcenter: true,
	    zIndex:1000,
	    constraintoviewport:true

	} 
); 
panel.setHeader('Error');
panel.setBody('<div id="errorM">'+str+'</div>');
panel.render(document.body);
	
}

function fadeMessagePanel(type,str){

	if(panel)
		panel.hide();

	var m = document.getElementById('siteMenu');

	var xVal = ((m.offsetWidth-450)/2);

	var dd = str.length*75;

	panel = new YAHOO.widget.Panel("message"+type, 
	{ 
		width:"450px",
	    close:false,  
	    visible:true, 
	    y:100,
	    x:xVal,
	    effect:{effect:YAHOO.widget.ContainerEffect.FADE,dur:200},
	    draggable:false,
	    constraintoviewport:true

	} 
); 
panel.setBody(str);
panel.render(document.body);


setTimeout('hidePanel()',dd); 

	
}

function messagePanel(str){

	if(panel)
		panel.hide();

	panel = new YAHOO.widget.Panel("message", 
	{ 
		width:"450px",
	    close:true,  
	    visible:true,  
	    draggable:false,
	    fixedcenter: true,
	    constraintoviewport:true

	} 
); 
panel.setHeader('Message');
panel.setBody(str);
panel.render(document.body);
	
}

function load(div, url){

        var content = document.getElementById(div);
        
        content.innerHTML = "";

        if (!wait) {

            // Initialize the temporary Panel to display while waiting for external content to load

            wait = 
                    new YAHOO.widget.Panel("wait",  
                                                    { width: "240px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: true,
                                                      visible: false
                                                    } 
                                                );
    
           wait.setHeader("Loading, please wait...");
           wait.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
           wait.render(document.body);

        }

        // Define the callback object for Connection Manager that will set the body of our content area when the content has loaded



        var callback = {
            success : function(o) {
                content.innerHTML = o.responseText;
                content.style.visibility = "visible";
                wait.hide();
            },
            failure : function(o) {
                content.innerHTML = o.responseText;
                content.style.visibility = "visible";
                content.innerHTML = "CONNECTION FAILED!";
                wait.hide();
            }
        }
    
        // Show the Panel
       	wait.show();
        
        // Connect to our data source and load the data
        var conn = YAHOO.util.Connect.asyncRequest("GET", url, callback);
}

// Define various event handlers for Dialog
var handleSubmit = function() {
	this.submit();
};

// Define various event handlers for Dialog
var handleEditSubmit = function() {
	this.submit();
};

var handleCancel = function() {
	this.cancel();
};

var handleEditSuccess = function(o) {
	var response = eval("("+o.responseText+")");
	if(response == "error")
		errorPanel('Could not save');

};

var handleSaveSuccess = function(o) {
	var response = eval("("+o.responseText+")");
	if(response['error'])
		errorPanel(response['error']);
	else {
		// refresh whole page
		window.location = unescape(window.location.pathname);
	}
};

var handleResetSuccess = function(o) {

	// refresh whole page
	stopMessage = true;
	window.location = unescape(window.location.pathname);

};

var handleFailure = function(o) {
	if(gen)
		gen.destroy();
	errorPanel("Connection failed");
};

function save() {

	var nameLoaded = function(o){

		wait.hide();

		var response = eval("("+o.responseText+")");

		if(dialog)
			dialog.destroy();

		dialog = new YAHOO.widget.Dialog("save", 
		{ 
			width:"400px",
	   	 visible:true,  
	   	 draggable:true,
	   	 fixedcenter: true,
	  	  constraintoviewport:true,
	  	  buttons : [ { text:"Submit", handler:handleSubmit, isDefault:true }, { text:"Cancel", handler:handleCancel } ]
		} 
); 

		dialog.callback = { success: handleSaveSuccess, failure: handleFailure };

		var name = response['name'];
	
		dialog.setHeader('Save Wizard Configuration');
		dialog.setBody('<form action="?save" method="post"><div id="save"><div class="saveDiv">Name this Configuration<br/><input type="text" name="saveName" class="inputField" value="'+name+'"></div></div></form>');
		dialog.render(document.body);

	}


	var callback =
	{
 	 success:nameLoaded,
 	 failure: handleFailure
	};

	if (!wait) {

            // Initialize the temporary Panel to display while waiting for external content to load

            wait = 
                    new YAHOO.widget.Panel("wait",  
                                                    { width: "240px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: true,
                                                      visible: false
                                                    } 
                                                );
    
           wait.setHeader("Loading, please wait...");
           wait.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
           wait.render(document.body);

        } else
		wait.show();

	var request = YAHOO.util.Connect.asyncRequest('POST', '?loadName', callback);

}

function saveThis() {

	var loaded = document.getElementById('loaded').value;

	var loadSuccess = function(o){

		messagePanel("Wizard config saved");

	}

	var callback =
	{
 	 success:loadSuccess,
 	 failure: handleFailure
	};
	
	var request = YAHOO.util.Connect.asyncRequest('POST', '?saved&loadSaved='+loaded+'&loaded='+loaded, callback);

}

function reset() {

	if(dialog)
		dialog.destroy();

	dialog = new YAHOO.widget.Dialog("save", 
	{ 
		width:"400px",
	    visible:true,  
	    draggable:true,
	    fixedcenter: true,
	    constraintoviewport:true,
	    buttons : [ { text:"Yes", handler:handleSubmit, isDefault:true }, { text:"No", handler:handleCancel } ]
	} 
); 

	dialog.callback = { success: handleResetSuccess, failure: handleFailure };

	dialog.setHeader('Start Over?');
	dialog.setBody('<form action="?do=server" method="post">Are you sure you want to start over?</form>');
	dialog.render(document.body);

}

function loadReset() {

	if(dialog)
		dialog.destroy();

	dialog = new YAHOO.widget.Dialog("save", 
	{ 
		width:"400px",
	    visible:true,  
	    draggable:true,
	    fixedcenter: true,
	    constraintoviewport:true,
	    buttons : [ { text:"Yes", handler:handleSubmit }, { text:"No", handler:handleCancel } ]
	} 
); 

	dialog.callback = { success: handleResetSuccess, failure: handleFailure };

	dialog.setHeader('Load Previous Wizard');
	dialog.setBody('<form action="?wizard=unload" method="post">Do you want to use the last wizard you were working on?</form>');
	dialog.render(document.body);

}

function handleConfigDelete() {

	document.getElementById('loadConfigForm').action = "?delConfig";
	this.submit();

}

function loadConfig(){

	if(dialog)
		dialog.destroy();

	var loadSuccess = function(o){

		wait.hide();

		if(o.responseText !== undefined){
			

			var lists = eval("("+o.responseText+")");
			
			if(lists.length == 0)
				alert('You have no saved configs');
				
			else {	
		
			dialog = new YAHOO.widget.Dialog("load", 
			{ 
				width:"400px",
	   		 visible:true,
			fixedcenter: true,  
	   		 draggable:true,
	   	 	constraintoviewport:true,
	  	 	 buttons : [ { text:"Load", handler:handleSubmit}, { text:"Delete", value:"delete", handler:handleConfigDelete }, { text:"Cancel", handler:handleCancel } ]
			} 
			); 

			dialog.callback = { success: handleResetSuccess, failure: handleFailure };

			var saved = '<select name="loadSaved" class="wizardDropDown">';
	
			for(i=0;i<lists.length;i++){

				saved += '<option value="'+lists[i]['id']+'">'+lists[i]['name']+'</option>';

			}

			saved += '</select>';

			dialog.setHeader('Load a Saved Config');
			dialog.setBody('<form action="?saved" method="post" id="loadConfigForm">Choose one of your saved Wizard Configurations<br/>'+saved+'</form>');
			dialog.render(document.body);
			}

		}
	}

	var callback =
	{
 	 success:loadSuccess,
 	 failure: handleFailure
	};

	if (!wait) {

            // Initialize the temporary Panel to display while waiting for external content to load

            wait = 
                    new YAHOO.widget.Panel("wait",  
                                                    { width: "240px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: true,
                                                      visible: false
                                                    } 
                                                );
    
           wait.setHeader("Loading, please wait...");
           wait.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
           wait.render(document.body);

        } else
		wait.show();

	var request = YAHOO.util.Connect.asyncRequest('POST', '?saved', callback);

}

function updateWizardValue(obj){

	var callback =
	{
 	 failure: handleFailure
	};

	var request = YAHOO.util.Connect.asyncRequest('POST', '?saveVar='+obj.id+'&value='+obj.value, callback);

}

function menu(what){


	if(oMenu)
		oMenu.destroy();

	oMenu = new YAHOO.widget.Menu("basicmenu", { "x":mX, "y":mY});

	oMenu.addItems([

        { text: "Edit", url: "javascript:edit('"+what+"');" },
        { text: "Delete", url: "?del="+what },

    ]);

	oMenu.render("rendertarget");
	oMenu.show();


}


function updateCalcSuccess(o) {

	if(timedout)
		return false;

	var response = eval("("+o.responseText+")");
	clearTimeout(timer);
	
	if(response['error']){
		update('tab2');
		gen.destroy();
		errorPanel(response['error']);
		// select the right tab
		var t = tabView.getTab(response['tab']);
		tabView.set('activeTab',t);
	} else {
		// refresh whole page
		if(response['showWarning']){
			gen.destroy();
			warning();
		} else if(response['showWarning2']){
			gen.destroy();
			warning2();
		} else
			window.location = unescape(window.location.pathname);
	}

}

function updateCalcSuccess2() {

	if(timedout)
		return false;

	//var response = JSON.parse(con.data());
	
	var jsontext = ''+con.data();
	var response;
	
	if(this.JSON){
	
		response = JSON.parse(jsontext);
	
	} else {
	
		response = eval("("+jsontext+")");
	
	}
	
	clearTimeout(timer);
	
	if(response['error']){
		//update('tab2');
		gen.hide();
		errorPanel(response['error']);
		// select the right tab
		var t = tabView.getTab(response['tab']);
		tabView.set('activeTab',t);
	} else {
		
		// refresh whole page
		if(response['showWarning']){
			gen.hide();
			warning();
		} else if(response['showWarning2']){
			gen.hide();
			warning2();
		} else
			window.location = unescape(window.location.pathname);
	}

}

function updateCalc(){
	
	timedout = false;

	var callback =
	{
 	 success: updateCalcSuccess,
 	 failure: handleFailure
	};

	gen = new YAHOO.widget.Panel("wait",  
                                                    { width: "320px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: false,
                                                      visible: false
                                                    } 
                                                );
    
        gen.setHeader("Generating Recommendations, please wait...");
        gen.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
        gen.render(document.body);

	gen.show();

	//YAHOO.util.Connect.setForm('calcForm');

	//var request = YAHOO.util.Connect.asyncRequest('POST', '?updateCalc=cameras', callback);
	
	con = new Connector({"inputsAllowed":"text,checkbox,select"});
	con.connect('calcForm',document.getElementById('calcForm').action+'?updateCalc=cameras');
	// send the cart
	con.onDataLoad(updateCalcSuccess2);
	con.send();
	
	// start a count down
	timer = setTimeout('updateTimeout()',120000);

}

function updateTimeout(){

	if(gen)
		gen.hide();
		
	timedout = true;	
	
	errorPanel("Processing your recommendation has timed out. Please try again.");

}

function edit(what){


	if(dialog)
		dialog.destroy();

	var loadSuccess = function(o){

		wait.hide();

		if(o.responseText !== undefined){
			

			var data = eval("("+o.responseText+")");

			var formData = data['formData'];

			dialog = new YAHOO.widget.Dialog("load", 
			{ 
				width:"400px",
	   		 visible:true,
			fixedcenter: true,  
	   		 draggable:true,
	   	 	constraintoviewport:true,
	  	 	 buttons : [ { text:"Update", handler:handleEditSubmit, isDefault:true }, { text:"Cancel", handler:handleCancel } ]
			}); 

			dialog.callback = { success: handleSaveSuccess, failure: handleFailure };


			dialog.setHeader('Edit');
			dialog.setBody('<form action="?update='+what+'" method="post">Modify any of your settings below<br/><br/>'+formData+'<br/><br/></form>');
			dialog.render(document.body);


		}
	}

	var callback =
	{
 	 success:loadSuccess,
 	 failure: handleFailure
	};

	if (!wait) {

            // Initialize the temporary Panel to display while waiting for external content to load

            wait = 
                    new YAHOO.widget.Panel("wait",  
                                                    { width: "240px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: true,
                                                      visible: false
                                                    } 
                                                );
    
           wait.setHeader("Loading, please wait...");
           wait.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
           wait.render(document.body);

        } else
		wait.show();

	var request = YAHOO.util.Connect.asyncRequest('POST', '?load='+what, callback);

}

function getMouseXY(evnt){

	var scrollAmount = window.pageYOffset ? window.pageYOffset : document.documentElement.scrollTop;

	if (isIE){

		mX = event.clientX;
		mY = event.clientY+scrollAmount;
	} else {

		mX = evnt.clientX;
		mY = evnt.clientY+scrollAmount;

	}

}
function showTip(id){

	
	tip = new YAHOO.widget.Tooltip("tt2", { context: id , autodismissdelay: 1000});


}
function update(id){

	// send data
	
	 gen = new YAHOO.widget.Panel("wait",  
                                                    { width: "320px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: false,
                                                      visible: false
                                                    } 
                                                );
    
        gen.setHeader("Updating...");
        gen.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
        gen.render(document.body);

	gen.show();
	
	var updateCamSuccess = function(o){

		if(gen)
			gen.hide();

		var response = eval("("+o.responseText+")");
		
		// if workstation don't worry about this code
		
		//if(tabView.get('tabs').length > 1){
		
			if(response['disable'] == "false"){
			
				//var tab0 = tabView.getTab(0); tab0.set('disabled',false);
				//var tab1 = tabView.getTab(1); tab1.set('disabled',false);
				//if(add_btn)
					//add_btn.set('disabled',false);	
				classer = "button";
				app = "addNewCamNextStep('cscPageHeader',2,3);";
				//sbtCalc.set('disabled',false);

			} else {

				//var tab0 = tabView.getTab(0); tab0.set('disabled',true);
				//var tab1 = tabView.getTab(1); tab1.set('disabled',true);
				//if(add_btn)
					//add_btn.set('disabled',true);
				classer = "button-disabled";
				app = "";
				//sbtCalc.set('disabled',true);

			}
		
		//}
		if(response['error']){
			
			if(response['error'] == "warning2")
				warning2();
			else 
				errorPanel(response['error']);
		}else {
			// refresh whole page
			//if(tabView.get('tabs').length > 1){
				//if(document.getElementById(id))
					//document.getElementById(id).innerHTML = response['html'];
				document.getElementById('tab2').innerHTML = response['settingsHtml']+'<br/><br/><div style="width:100%;text-align:center"><a href="#" onclick="'+app+'return false;"><div id="addCameraButton" class="'+classer+'" style="width:120px">NEXT STEP</div></a></div>';
			//}
		}

	}

	var callback =
	{
 	 success: updateCamSuccess,
 	 failure: handleFailure
	};

	YAHOO.util.Connect.setForm('calcForm');
	var request = YAHOO.util.Connect.asyncRequest('POST', '?updateData=cameras.0', callback);

}

function deleteCamera(id){

	// send data

	var deleteCameraSuccess = function(o){

		var response = eval("("+o.responseText+")");
		if(response['error'])
			errorPanel(response['error']);
		else {
			// refresh whole page
			//document.getElementById('tab2').innerHTML = response['settingsHtml'];
			// remove tab
			
			totalCams--;
			
			var t = tabView.getTab(id+1);
			tabView.removeTab(t);
			
			a = tabView.get('tabs');
			
			//rename tabs
			for(var i=id+1;i<a.length;i++){
			
				var tmp = tabView.getTab(i);
				tmp.set('label','Camera '+i+' ('+response['title'][i-1]+')');
				tmp.set('content',response['html'][i-1]);
			
			}
		}

	}

	var callback =
	{
 	 success: deleteCameraSuccess,
 	 failure: handleFailure
	};

	YAHOO.util.Connect.setForm('calcForm');
	var request = YAHOO.util.Connect.asyncRequest('POST', '?deleteCamera='+id, callback);

}

function addNew(){
	
	totalCams++;
	
	var callback =
	{
 	 success: addNewNext,
 	 failure: handleFailure
	};

	YAHOO.util.Connect.setForm('calcForm');
	var request = YAHOO.util.Connect.asyncRequest('POST', '?addCamera=yes', callback);

}

function addNewCam(){

	totalCams++;
	
	var callback =
	{
 	 success: addNewNextCam,
 	 failure: handleFailure
	};

	YAHOO.util.Connect.setForm('calcForm');
	var request = YAHOO.util.Connect.asyncRequest('POST', '?addCamera=yes', callback);

}

function addNewCamNextStep(prefix,step,totalSteps){

	if(totalCams > 0){
	
		var tab = tabView.getTab(totalCams);
		tabView.set('activeTab',tab);
	
	} else {
	
		addNewCam();
	
	}
	
	
	update('tab2');
	goToStep(prefix,step,totalSteps);

}

function goToStep(prefix,step,totalSteps){

	for(var i=1;i<=totalSteps;i++){
	
		if(i == step){
		
			document.getElementById(prefix+step).style.display = "block";
		
		} else {
			
			document.getElementById(prefix+i).style.display = "none";
			
		}
	
	}

}

function addNewNextCam(o){

	var response = eval("("+o.responseText+")");

	if(response['done']){
		//update('tab2');
		//var tab1 = tabView.getTab(1); tab1.set('active',true);
		
		// need to add new tab for the new camera
		var tab =  new YAHOO.widget.Tab({ label: 'Camera '+totalCams+' ('+response['title']+')', content: response['content'] });
		tabView.addTab(tab); 
		
		//var tab0 = tabView.getTab(0); tab0.set('active',false);
		tabView.set('activeTab',tab);
		
	}

}

function addNewNext(o){

	var response = eval("("+o.responseText+")");

	if(response['done']){
		update('tab2');
		var tab1 = tabView.getTab(1); tab1.set('active',true);
		var tab0 = tabView.getTab(0); tab0.set('active',false);
		tabView.set('activeTab',tab1);
		
	}

}

function updater(){

	//intervalID = setInterval("update('tab2')",500);
}

function handleUpgradeSuccess(o){

	var response = eval("("+o.responseText+")");
	if(response['error']){
		errorPanel(response['error']);
	}

}

function upgradeUpdater(){

	var callback =
	{
	 success: handleUpgradeSuccess,
 	 failure: handleFailure
	};

	YAHOO.util.Connect.setForm('calcForm');
	var request = YAHOO.util.Connect.asyncRequest('POST', '?updateUpgrade=yes', callback);

}

function clearUpdater(){

	clearInterval(intervalID);
	intervalID = false;

}

function noCustom(id){

	document.getElementById('camTypeCustom'+id).checked = false;
	document.getElementById('camTypeCam'+id).checked = true;
	

}

function updateCamera(id,whichCamera){

	// send data

	var updateCameraSuccess = function(o){

		var response = eval("("+o.responseText+")");

		// refresh whole page
		var t = tabView.getTab(whichCamera+1);
		
		t.set('content',response['html']);
		

	}

	var callback =
	{
 	 success: updateCameraSuccess,
 	 failure: handleFailure
	};

	YAHOO.util.Connect.setForm('calcForm');
	var request = YAHOO.util.Connect.asyncRequest('POST', '?updateCamera='+whichCamera, callback);
	
	return false;

}
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_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_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];}
}

function updateSlider(sliderObj,text,val,min,max){

	slider = sliderObj;
	intervalID = setInterval("updateSliderValue('"+text+"',"+val+","+min+","+max+")",10);
	
}

function updateSliderValue(text,val,min,max){

	var i = document.getElementById(text).value;
	if(i > max)
		i = max;
	if(i < min)
		i = min;
	val = Math.round(i/val);
	slider.setValue(val);
}

function createSlider(val,def,minValue,maxValue){

    var Event = YAHOO.util.Event,
        Dom   = YAHOO.util.Dom,
        lang  = YAHOO.lang,
        slider, 
        bg="slider-bg", thumb="slider-thumb", 
        valuearea="slider-value", textfield=val

    // The slider can move 0 pixels up
    var topConstraint = 0;

    // The slider can move 200 pixels down
    var bottomConstraint = 200;

    // Custom scale factor for converting the pixel offset into a real value
    var scaleFactor = (maxValue-minValue)/200;

    // The amount the slider moves when the value is changed with the arrow
    // keys
    var keyIncrement = 1;

    var tickSize = 1;

    Event.onDOMReady(function() {

        slider = YAHOO.widget.Slider.getHorizSlider(bg, 
                         thumb, topConstraint, bottomConstraint);

        slider.getRealValue = function() {
            return Math.round(this.getValue() * scaleFactor);
        }

        slider.subscribe("change", function(offsetFromStart) {

            var valnode = Dom.get(valuearea);
            var fld = Dom.get(textfield);

            // Display the pixel value of the control
            valnode.value = offsetFromStart;

            // use the scale factor to convert the pixel offset into a real
            // value
            var actualValue = slider.getRealValue();

            // update the text box with the actual value
            fld.value = actualValue;
	

        });

	slider.setValue(Math.round(def/scaleFactor));

	Event.on(textfield, "blur", function(e) {

            clearUpdater();
            
        });
        
	Event.on(slider, "click", function(e) {

            clearUpdater();
            
        });

	Event.on(textfield, "focus", function(e) {

            updateSlider(slider,textfield,scaleFactor,minValue,maxValue);
            
        });	

        
    });

}

function switchToVS(){

	// cameras tab to Monitors and Streams
	var tab1 = tabView.getTab(1); tab1.set('label','Monitors and Streams')

}

function showCamera(index){
	if(cam)
		cam.style.display = "none"; // hide previous
	cam = document.getElementById('cam'+index);
	cam.style.display = "block";
}

function getRecommendation(){

	
	var callback =
	{
 	 success: updateCalcSuccess,
 	 failure: handleFailure
	};

	 gen = new YAHOO.widget.Panel("wait",  
                                                    { width: "320px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: true,
                                                      visible: false
                                                    } 
                                                );
    
        gen.setHeader("Generating Recommendations, please wait...");
        gen.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
        gen.render(document.body);

	gen.show();

	YAHOO.util.Connect.setForm('wizardForm');

	var request = YAHOO.util.Connect.asyncRequest('POST', '?skip=Skip to Recommendation', callback);

}

function getServer(){

	
	var callback =
	{
 	 success: updateCalcSuccess,
 	 failure: handleFailure
	};

	 gen = new YAHOO.widget.Panel("wait",  
                                                    { width: "320px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: true,
                                                      visible: false
                                                    } 
                                                );
    
        gen.setHeader("Generating Recommendations, please wait...");
        gen.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
        gen.render(document.body);

	gen.show();

	YAHOO.util.Connect.setForm('calcForm');

	var request = YAHOO.util.Connect.asyncRequest('POST', '?updateCalc=cameras', callback);

}

var handleWarningSubmit = function(o){

	
	YAHOO.util.Connect.setForm('warningForm');
	
	var action = document.getElementById('warningForm').action;

	var callback = {success: dialog.hide()};

	var request = YAHOO.util.Connect.asyncRequest('POST', action, callback);	
	

}

function strandWarning(){

	var loadSuccess = function(o){

		wait.hide();

		var vars = eval("("+o.responseText+")");		

		dialog = new YAHOO.widget.Dialog("load", 
			{ 
				width:"600px",
			visible:true,
			fixedcenter: true,  
	   		 draggable:true,
	   	 	constraintoviewport:true,
	  	 	 buttons : [ { text:"Send", handler:handleSubmit}, { text:"Cancel", handler:handleCancel } ]
			}); 

		dialog.callback = { success: handleWarningSubmit, failure: handleFailure };


		var contactForm = '<div class="resultsLeft">Name: </div><div class="resultsRight"><input type="text" name="contactName" id="contactName" value="'+vars.name+'" style="width:90%" /></div><div style="clear:both"></div>';

		contactForm += '<div class="resultsLeft">E-mail: </div><div class="resultsRight"><input type="text" name="contactEmail" id="contactEmail" value="'+vars.email+'" style="width:90%" /></div><div style="clear:both"></div>';
		contactForm += '<div class="resultsLeft">Phone: </div><div class="resultsRight"><input type="text" name="contactPhone" id="contactPhone" value="'+vars.phone+'" style="width:90%" /></div><div style="clear:both"></div>';
		contactForm += '<div class="resultsLeft">Comments: </div><div class="resultsRight"><textarea name="contactComments" id="contactComments" rows="4" style="width:90%" /></textarea></div><div style="clear:both"></div>';

		dialog.setHeader('Strand Warning');
		dialog.setBody('<form action="?contact" method="post" id="warningForm"><div class="resultsLeft" style="line-height:100%"><img src="images?img=warning.png" alt="" /></div><div class="resultsRight">Due to limitations of the Strand software, we recommend contacting us so that we can create a custom solution for you that will be as efficient as possible.<br/><br/>Fill in your contact info below<br/><br/>'+contactForm+'</div><div style="clear:both"></div></form>');	
		dialog.render(document.body);

	}	

	var callback =
	{
 	 success:loadSuccess,
 	 failure: handleFailure
	};

	if (!wait) {

            // Initialize the temporary Panel to display while waiting for external content to load

            wait = 
                    new YAHOO.widget.Panel("wait",  
                                                    { width: "240px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: true,
                                                      visible: false
                                                    });
    
           wait.setHeader("Loading, please wait...");
           wait.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
           wait.render(document.body);

        } else
		wait.show();

	var request = YAHOO.util.Connect.asyncRequest('POST', '?contactVars', callback);


}

function warning(){

	var loadSuccess = function(o){

		wait.hide();

		var vars = eval("("+o.responseText+")");		

		dialog = new YAHOO.widget.Dialog("load", 
			{ 
				width:"600px",
			visible:true,
			fixedcenter: true,  
	   		 draggable:true,
	   	 	constraintoviewport:true,
	  	 	 buttons : [ { text:"Send", handler:handleSubmit}, { text:"Cancel", handler:handleCancel } ]
			} 
			); 

		dialog.callback = { success: handleWarningSubmit, failure: handleFailure };


		var contactForm = '<div class="resultsLeft">Name: </div><div class="resultsRight"><input type="text" name="contactName" id="contactName" value="'+vars.name+'" style="width:90%" /></div><div style="clear:both"></div>';

		contactForm += '<div class="resultsLeft">E-mail: </div><div class="resultsRight"><input type="text" name="contactEmail" id="contactEmail" value="'+vars.email+'" style="width:90%" /></div><div style="clear:both"></div>';
		contactForm += '<div class="resultsLeft">Phone: </div><div class="resultsRight"><input type="text" name="contactPhone" id="contactPhone" value="'+vars.phone+'" style="width:90%" /></div><div style="clear:both"></div>';
		contactForm += '<div class="resultsLeft">Comments: </div><div class="resultsRight"><textarea name="contactComments" id="contactComments" rows="4" style="width:90%" /></textarea></div><div style="clear:both"></div>';

		dialog.setHeader('Warning');
		dialog.setBody('<form action="?contact" method="post" id="warningForm"><div class="resultsLeft" style="line-height:100%"><img src="images?img=warning.png" alt="" /></div><div class="resultsRight">To get the best possible solution, we recommend contacting us so that we can create a custom solution for you that will be as efficient as possible.<br/><br/>Fill in your contact info below<br/><br/>'+contactForm+'</div><div style="clear:both"></div></form>');	
		dialog.render(document.body);

	}	

	var callback =
	{
 	 success:loadSuccess,
 	 failure: handleFailure
	};

	if (!wait) {

            // Initialize the temporary Panel to display while waiting for external content to load

            wait = 
                    new YAHOO.widget.Panel("wait",  
                                                    { width: "240px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: true,
                                                      visible: false
                                                    } 
                                                );
    
           wait.setHeader("Loading, please wait...");
           wait.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
           wait.render(document.body);

        } else
		wait.show();

	var request = YAHOO.util.Connect.asyncRequest('POST', '?contactVars', callback);


}

function warning2(){

	
	var loadSuccess = function(o){

		wait.hide();

		var vars = eval("("+o.responseText+")");		

		dialog = new YAHOO.widget.Dialog("load", 
			{ 
				width:"740px",
			visible:true,
			fixedcenter: true,  
	   		 draggable:true,
	   	 	constraintoviewport:true}); 

		dialog.callback = { success: handleWarningSubmit, failure: handleFailure };

		dialog.setHeader('Contact your local CSC Representative');
		dialog.setBody('<img src="images?img=repmap.jpg" alt="">');	
		dialog.render(document.body);

	}	

	var callback =
	{
 	 success:loadSuccess,
 	 failure: handleFailure
	};

	if (!wait) {

            // Initialize the temporary Panel to display while waiting for external content to load

            wait = 
                    new YAHOO.widget.Panel("wait",  
                                                    { width: "240px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: false,
                                                      visible: false
                                                    } 
                                                );
    
           wait.setHeader("Loading, please wait...");
           wait.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
           wait.render(document.body);

        } else
		wait.show();

	var request = YAHOO.util.Connect.asyncRequest('POST', '?contactVars', callback);


}

function contactUs(){

	var loadSuccess = function(o){

		wait.hide();
		panel.hide();

		var vars = eval("("+o.responseText+")");		

		dialog = new YAHOO.widget.Dialog("load", 
			{ 
				width:"600px",
			visible:true,
			fixedcenter: true,  
	   		 draggable:true,
	   	 	constraintoviewport:true,
	  	 	 buttons : [ { text:"Send", handler:handleSubmit}, { text:"Cancel", handler:handleCancel } ]
			} 
			); 

		dialog.callback = { success: handleWarningSubmit, failure: handleFailure };


		var contactForm = '<div class="resultsLeft">Name: </div><div class="resultsRight"><input type="text" name="contactName" id="contactName" value="'+vars.name+'" style="width:90%" /></div><div style="clear:both"></div>';

		contactForm += '<div class="resultsLeft">E-mail: </div><div class="resultsRight"><input type="text" name="contactEmail" id="contactEmail" value="'+vars.email+'" style="width:90%" /></div><div style="clear:both"></div>';
		contactForm += '<div class="resultsLeft">Phone: </div><div class="resultsRight"><input type="text" name="contactPhone" id="contactPhone" value="'+vars.phone+'" style="width:90%" /></div><div style="clear:both"></div>';
		contactForm += '<div class="resultsLeft">Comments: </div><div class="resultsRight"><textarea name="contactComments" id="contactComments" rows="4" style="width:90%" /></textarea></div><div style="clear:both"></div>';

		dialog.setHeader('Contact Us');
		dialog.setBody('<form action="?contact" method="post" id="warningForm">To get the best possible solution, we recommend contacting us so that we can create a custom solution for you that will be as efficient as possible.<br/><br/>Fill in your contact info below<br/><br/>'+contactForm+'</div><div style="clear:both"></form>');	
		dialog.render(document.body);

	}	

	var callback =
	{
 	 success:loadSuccess,
 	 failure: handleFailure
	};

	if (!wait) {

            // Initialize the temporary Panel to display while waiting for external content to load

            wait = 
                    new YAHOO.widget.Panel("wait",  
                                                    { width: "240px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: true,
                                                      visible: false
                                                    } 
                                                );
    
           wait.setHeader("Loading, please wait...");
           wait.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
           wait.render(document.body);

        } else
		wait.show();

	var request = YAHOO.util.Connect.asyncRequest('POST', '?contactVars', callback);


}

function enterCode(){

	//document.getElementById('enterCode').style.display = '';

}

function claimPrize(){

	//document.getElementById('enterCode').style.display = 'none';

	var claimPrizeDone = function(o){
		
		dialog.hide();
		messagePanel('Your prize has been claimed. We will send your prize as soon as possible.');
		
	}

	var loadSuccess = function(o){

		wait.hide();
		if(panel)
			panel.hide();

		var vars = eval("("+o.responseText+")");	

		if(vars.error){
			
			errorPanel('Incorrect Prize Code');
			
		} else {

			dialog = new YAHOO.widget.Dialog("load", 
				{ 
					width:"600px",
				visible:true,
				fixedcenter: true,  
				 draggable:true,
				constraintoviewport:true,
				 buttons : [ { text:"Send", handler:handleSubmit}, { text:"Cancel", handler:handleCancel } ]
				} 
				); 
	
			dialog.callback = { success: claimPrizeDone, failure: handleFailure };
	
	
			var contactForm = '<div class="resultsLeft">Name: </div><div class="resultsRight"><input type="text" name="contactName" id="contactName" value="'+vars.name+'" style="width:90%" /></div><div style="clear:both"></div>';
	
			contactForm += '<div class="resultsLeft">E-mail: </div><div class="resultsRight"><input type="text" name="contactEmail" id="contactEmail" value="'+vars.email+'" style="width:90%" /></div><div style="clear:both"></div>';
			contactForm += '<div class="resultsLeft">Phone: </div><div class="resultsRight"><input type="text" name="contactPhone" id="contactPhone" value="'+vars.phone+'" style="width:90%" /></div><div style="clear:both"></div>';
			contactForm += '<div class="resultsLeft">Address: </div><div class="resultsRight"><textarea name="contactAddress" id="contactAddress" rows="4" style="width:90%" /></textarea></div><div style="clear:both"></div>';
	
			dialog.setHeader('Claim Prize');
			dialog.setBody('<form action="?claimPrize" method="post" id="warningForm">Fill in your contact info below to claim your prize. Make sure to enter the address you want to the prize shipped to.<br/><br/>'+contactForm+'</div><div style="clear:both"></form>');	
			dialog.render(document.body);
		
		}

	}	

	var callback =
	{
 	 success:loadSuccess,
 	 failure: handleFailure
	};

	if (!wait) {

            // Initialize the temporary Panel to display while waiting for external content to load

            wait = 
                    new YAHOO.widget.Panel("wait",  
                                                    { width: "240px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: true,
                                                      visible: false
                                                    });
    
           wait.setHeader("Loading, please wait...");
           wait.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
           wait.render(document.body);

        } else
		wait.show();


	var request = YAHOO.util.Connect.asyncRequest('POST', '?code='+document.getElementById('code').value, callback);


}

function removeTab(tab){

	var tabber = tabView.getTab(tab-1);
	tabber.set('disabled',true);
	
}
function goToTab(tab){

	var tabber = tabView.getTab(0);
	tabber.set('active',false);

	//var tabber = tabView.getTab(1);
	//tabber.set('active',false);

	//var tabber = tabView.getTab(2);
	//tabber.set('active',false);

	var tabber = tabView.getTab(tab-1);
	if(tabber){
		tabber.set('active',true);
		tabView.set('activeTab',tabber);
	}
	//console.log('active = true');

}
function pdf(){

	if(rTabView){
		obj = rTabView.get('activeIndex');
		//console.log(obj);
		var win = window.open("?pdf="+(obj+1),"PDF","height=600,width=800,scrollbars=yes");
	}

}

function switchPDF(num){

	//if(rTabView){
		//obj = rTabView.get('activeIndex');
		//console.log(obj);
		var win = window.open("?pdf="+(num),"PDF","height=600,width=800,scrollbars=yes");
	//}

}

function countdown(){
	seconds--;
	messagePanel(responseText+' '+seconds+' second(s)');
	setTimeout("countdown()", 1000);
}

function go(){
		
	window.location = url;
		
}

var url = '';
var responseText = '';
var seconds = 0;
function checkForm(){

	action = document.getElementById('account').action;
	
	var formsuccess = function(o){
		
		var response = eval("("+o.responseText+")");

		if(response['error']){
			
			errorPanel(response['error']);
			
		} else {
			
			// go to logout
			
			responseText = response['good'];
			seconds = 10;
			messagePanel(responseText+' '+seconds+' second(s)');
			url = response['url'];
			setTimeout("countdown()", 1000);
			setTimeout("go()", 10000);
			
		}
		
	}
	
	var callback =
	{
	
 	 success:formsuccess,
 	 failure: handleFailure
	};
	
	YAHOO.util.Connect.setForm('account');
	
	var request = YAHOO.util.Connect.asyncRequest('POST', action, callback);
}

function deleteImage(){
	
	setOpacity('uploader');
	
	// show uploadMessage
	showMessage('deleteMessage','uploader');
	
	document.getElementById('upload').style.display = "none";
	document.getElementById('remove').style.display = "none";
	
	var formsuccess = function(o){
	
		var response = eval("("+o.responseText+")");
	
		document.getElementById('thumb').src = response['file']+'&rand='+Math.random()*10000;
		document.getElementById('thumb').onload = function(){
			
			document.getElementById('upload').style.display = "";
			document.getElementById('remove').style.display = "";
			
			hideMessage('deleteMessage');
			unsetOpacity('uploader');
			
		}
	}
	
	var action = document.getElementById('frmupload').action;
	
	var callback =
	{
	
 	 upload:formsuccess,
 	 failure: handleFailure
	 
	};
	
	YAHOO.util.Connect.setForm('frmupload', true);
	
	var request = YAHOO.util.Connect.asyncRequest('POST', action+'?delete=true', callback);
	
}

function showMessage(obj,pt){
	
	if (document.all){
   	 	document.all(obj).style.display = "block";
		document.all(obj).style.left = findPosX(document.all(pt))+'px';
		document.all(obj).style.top = findPosY(document.all(pt))+'px';
		document.all(obj).style.width = document.all(pt).offsetWidth+'px';
		document.all(obj).style.height = document.all(pt).offsetHeight+'px';
	 } else if (!document.all && document.getElementById) {      
		document.getElementById(obj).style.display = "block";
		document.getElementById(obj).style.left = findPosX(document.getElementById(pt))+'px';
		document.getElementById(obj).style.top = findPosY(document.getElementById(pt))+'px';
		document.getElementById(obj).style.width = document.getElementById(pt).offsetWidth+'px';
		document.getElementById(obj).style.height = document.getElementById(pt).offsetHeight+'px';
	 }
	
}

function hideMessage(obj){
	
	if (document.all){
   	 	document.all(obj).style.display = "none";
	 } else if (!document.all && document.getElementById) {      
		document.getElementById(obj).style.display = "none";
	 }
	
}

function uploadImage(){
	
	setOpacity('uploader');
	
	// show uploadMessage
	showMessage('uploadMessage','uploader');
	
	document.getElementById('upload').style.display = "none";
	document.getElementById('remove').style.display = "none";
	
	var formsuccess = function(o){
	
		var response = eval("("+o.responseText+")");
	
		document.getElementById('thumb').src = response['file']+'&rand='+Math.random()*10000;
		document.getElementById('thumb').onload = function(){
			
			document.getElementById('upload').style.display = "";
			document.getElementById('remove').style.display = "";
			
			hideMessage('uploadMessage');
			unsetOpacity('uploader');
			
		}
	}
	
	var action = document.getElementById('frmupload').action;
	
	var callback =
	{
	
 	 upload:formsuccess,
 	 failure: handleFailure
	 
	};
	
	YAHOO.util.Connect.setForm('frmupload', true);
	
	var request = YAHOO.util.Connect.asyncRequest('POST', action+'?upload=true', callback);
	
}

// sets objects opacity
function setOpacity(objectId) {
  
  if (document.all){
   	 document.all(objectId).className = document.all(objectId).className+'hidden';
  } else if (!document.all && document.getElementById) {      
     document.getElementById(objectId).className  = document.getElementById(objectId).className+'hidden';
  }
}

// unsets objects opacity
function unsetOpacity(objectId) {
  
  if (document.all){
   	 document.all(objectId).className = document.all(objectId).className.replace('hidden','');
  } else if (!document.all && document.getElementById) {      
     document.getElementById(objectId).className  = document.getElementById(objectId).className.replace('hidden','');
  }
}
function findPosX(obj)
{
	var curleft = 0;
	if (obj.offsetParent)
	{
		while (obj.offsetParent)
		{
			curleft += obj.offsetLeft
			obj = obj.offsetParent;
		}
	}
	else if (obj.x)
		curleft += obj.x;
	return curleft;
}

function findPosY(obj)
{
	var curtop = 0;
	if (obj.offsetParent)
	{
		while (obj.offsetParent)
		{
			curtop += obj.offsetTop
			obj = obj.offsetParent;
		}
	}
	else if (obj.y)
		curtop += obj.y;
	return curtop;
}

function loginNow(){
	
	setOpacity('login');
	
	// show uploadMessage
	showMessage('loginMessage','login');
	
	document.getElementById('loginButton').style.display = "none";
	
	var formsuccess = function(o){
	
		if(o.responseText){
			
			if(o.responseText != "")
				o.responseText = "("+o.responseText+")";
			
			try {
				
				var response = eval(o.responseText);
		
			} catch(error){
			
				var action = document.getElementById('loginForm').action;
			
				var response = new Array();
				response['error'] = "An error occurred @ "+action;
			
			}
		
			if(response['error']){
				
				hideMessage('loginMessage');
				document.getElementById('loginButton').style.display = "";
				unsetOpacity('login');
				errorPanel(response['error']);
			
			} else {
				
				document.getElementById('loginForm').action = '';
				window.location = unescape(window.location.pathname);
				
			}
		} else {
		
			errorPanel("Error logging in");
		
		}

	}
	
	var action = document.getElementById('loginForm').action;
	
	var callback =
	{
	
 	 success:formsuccess,
 	 failure: handleFailure
	 
	};
	
	YAHOO.util.Connect.setForm('loginForm');
	
	var request = YAHOO.util.Connect.asyncRequest('POST', action+'?loginButton=true', callback);
	
}
function createFlash(name,fileSrc,w,h,showMenu,flashVars){
  var d = document.getElementById(name);
  d.innerHTML += '<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,29,0" width="'+w+'" height="'+h+'" id="'+name+'" name="'+name+'"> <param name="movie" value="'+fileSrc+'"><param name="quality" value="best"><param name="wmode" value="transparent"><param name="menu" value="'+showMenu+'"><param name="FlashVars" value="'+flashVars+'"><embed src="'+fileSrc+'" width="'+w+'" height="'+h+'" quality="best" pluginspage="http://www.macromedia.com/go/getflashplayer" type="application/x-shockwave-flash" id="'+name+'" name="'+name+'" FlashVars="'+flashVars+'" menu="'+showMenu+'" wmode="transparent" swLiveConnect="true" ></embed></object>';
}


function hidePanel(){
	
	if(panel)
		panel.hide();
	setTimeout('checkMessages()',3000);
	
}

var handleSQSubmit = function(o){

	
	YAHOO.util.Connect.setForm('sendQuote');
	
	var action = document.getElementById('sendQuote').action;

	var callback = {success: dialog.hide()};

	var request = YAHOO.util.Connect.asyncRequest('POST', action, callback);	
	

}

function sendQuote() {

		var loadSuccess = function(o){

		wait.hide();

		var vars = eval("("+o.responseText+")");		


		dialog = new YAHOO.widget.Dialog("load", 
			{ 
				width:"500px",
	   		 visible:true,
			fixedcenter: true,  
	   		 draggable:true,
	   	 	constraintoviewport:true,
	  	 	 buttons : [ { text:"Send", handler:handleSQSubmit}, { text:"Cancel", handler:handleCancel } ]
			}); 

		dialog.callback = { success: handleResetSuccess, failure: handleFailure };


		var contactForm = '<div style="padding:3px;margin-bottom:5px;font-weight:bold;font-size:14px">Recipient E-mail: </div><div><input type="text" name="manager" id="manager" value="" style="width:90%" /></div><div style="clear:both"></div>';

		contactForm += 'or<div style="padding:3px;margin-bottom:5px;font-weight:bold;font-size:14px">Select a Regional Manager: </div><div><select name="regManager" style="width:90%">';

		for(i=0;i<vars.length;i++){

			contactForm += '<option>'+vars[i]+'</option>';

		}
		

		contactForm += '</select></div><br/><div style="padding:3px;margin-bottom:5px;font-weight:bold;font-size:14px">Config Notes: </div><textarea name="configNotes" id="configNotes" cols="45" rows="5"></textarea><div style="clear:both"></div>';
	
		dialog.setHeader('Send Config');
		dialog.setBody('<form action="?sendQuote" method="post" id="sendQuote">Either enter your recipient\'s email address or select from a list of managers.<br/><br/>'+contactForm+'</form>');	
		dialog.render(document.body);

	}	

	var callback =
	{
 	 success:loadSuccess,
 	 failure: handleFailure
	};

	if (!wait) {

            // Initialize the temporary Panel to display while waiting for external content to load

            wait = 
                    new YAHOO.widget.Panel("wait",  
                                                    { width: "240px", 
                                                      fixedcenter: true, 
                                                      close: false, 
                                                      draggable: false, 
                                                      zindex:4,
                                                      modal: true,
                                                      visible: false
                                                    });
    
           wait.setHeader("Loading, please wait...");
           wait.setBody("<img src=\"image?img=rel_interstitial_loading.gif\"/>");
           wait.render(document.body);

        } else
		wait.show();

	var request = YAHOO.util.Connect.asyncRequest('POST', '?sendQuoteVars', callback);

}

function loadQuoteConfig(cfg){

	window.location = window.location.pathname+"?loadConfig="+cfg;

}
function attachToDiv(what,to,dir){

	if(document.getElementById(what) && document.getElementById(to)){
		
	// make the left, and top the same
	//document.getElementById(what).style.left = findPosX(document.getElementById(to))+'px';
	//document.getElementById(what).style.top = (findPosY(document.getElementById(to))-5)+'px';
	//document.getElementById(what).style.width = document.getElementById(to).offsetWidth+'px';
	//document.getElementById(what).style.height = document.getElementById(to).offsetHeight+'px';
	if(dir == "right"){
		
			document.getElementById(what).style.left = findPosX(document.getElementById(to))+(document.getElementById(to).offsetWidth-document.getElementById(what).offsetWidth)+'px';
			document.getElementById(what).style.top = (findPosY(document.getElementById(to))-5)+'px';

	} else if(dir == "leftbottom"){

			document.getElementById(what).style.top = findPosY(document.getElementById(to))+(document.getElementById(to).offsetHeight-document.getElementById(what).offsetHeight)+5+'px';
			document.getElementById(what).style.left = (findPosX(document.getElementById(to))+5)+'px';
	}
	}

}


//var handleThumbSubmit = function(o){

	//stopMessage = true;
	//YAHOO.util.Connect.setForm('uploadThumbnail',true);
	
	//var action = document.getElementById('uploadThumbnail').action;

	//var doner = function(o){

		//wait.hide();
		//dialog.hide();
		//refreshTable();
		//stopMessage = false;

	//}

	//var callback = {success: doner};

	//var request = YAHOO.util.Connect.asyncRequest('POST', action, callback);	
	
	
//}

function uploadThumbnail(what){


		if(!thumber){
           thumber = new YAHOO.widget.Dialog("upload", 
			{ 
				width:"500px",
	   		 visible:true,
			fixedcenter: true,  
	   		 draggable:true,
	   	 	constraintoviewport:true,
	  	 	 buttons : [ { text:"Upload Thumbnail Image", handler:handleSubmit}, { text:"Cancel", handler:handleCancel } ]
			} 
			); 
		
	
		thumber.setHeader('Upload Thumbnail Image');
		thumber.setBody('<form action="?upload='+what+'" method="post" name="uploadThumbnail" id="uploadThumbnail">Upload a new thumbnail image for '+what+'. File must be a JPEG and 70x70.<br/><br/><input type="file" name="uploadFile" id="uploadFile" value="" style="width:100%" /></form>');	
		thumber.render(document.body);

	}
		thumber.show();

}

// Flash Player Version Detection - Rev 1.6
// Detect Client Browser type
// Copyright(c) 2005-2006 Adobe Macromedia Software, LLC. All rights reserved.
var isIE  = (navigator.appVersion.indexOf("MSIE") != -1) ? true : false;
var isWin = (navigator.appVersion.toLowerCase().indexOf("win") != -1) ? true : false;
var isOpera = (navigator.userAgent.indexOf("Opera") != -1) ? true : false;

function ControlVersion()
{
	var version;
	var axo;
	var e;

	// NOTE : new ActiveXObject(strFoo) throws an exception if strFoo isn't in the registry

	try {
		// version will be set for 7.X or greater players
		axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.7");
		version = axo.GetVariable("$version");
	} catch (e) {
	}

	if (!version)
	{
		try {
			// version will be set for 6.X players only
			axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.6");
			
			// installed player is some revision of 6.0
			// GetVariable("$version") crashes for versions 6.0.22 through 6.0.29,
			// so we have to be careful. 
			
			// default to the first public version
			version = "WIN 6,0,21,0";

			// throws if AllowScripAccess does not exist (introduced in 6.0r47)		
			axo.AllowScriptAccess = "always";

			// safe to call for 6.0r47 or greater
			version = axo.GetVariable("$version");

		} catch (e) {
		}
	}

	if (!version)
	{
		try {
			// version will be set for 4.X or 5.X player
			axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.3");
			version = axo.GetVariable("$version");
		} catch (e) {
		}
	}

	if (!version)
	{
		try {
			// version will be set for 3.X player
			axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.3");
			version = "WIN 3,0,18,0";
		} catch (e) {
		}
	}

	if (!version)
	{
		try {
			// version will be set for 2.X player
			axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash");
			version = "WIN 2,0,0,11";
		} catch (e) {
			version = -1;
		}
	}
	
	return version;
}

// JavaScript helper required to detect Flash Player PlugIn version information
function GetSwfVer(){
	// NS/Opera version >= 3 check for Flash plugin in plugin array
	var flashVer = -1;
	
	if (navigator.plugins != null && navigator.plugins.length > 0) {
		if (navigator.plugins["Shockwave Flash 2.0"] || navigator.plugins["Shockwave Flash"]) {
			var swVer2 = navigator.plugins["Shockwave Flash 2.0"] ? " 2.0" : "";
			var flashDescription = navigator.plugins["Shockwave Flash" + swVer2].description;
			var descArray = flashDescription.split(" ");
			var tempArrayMajor = descArray[2].split(".");			
			var versionMajor = tempArrayMajor[0];
			var versionMinor = tempArrayMajor[1];
			var versionRevision = descArray[3];
			if (versionRevision == "") {
				versionRevision = descArray[4];
			}
			if (versionRevision[0] == "d") {
				versionRevision = versionRevision.substring(1);
			} else if (versionRevision[0] == "r") {
				versionRevision = versionRevision.substring(1);
				if (versionRevision.indexOf("d") > 0) {
					versionRevision = versionRevision.substring(0, versionRevision.indexOf("d"));
				}
			}
			var flashVer = versionMajor + "." + versionMinor + "." + versionRevision;
			//alert("flashVer="+flashVer);
		}
	}
	// MSN/WebTV 2.6 supports Flash 4
	else if (navigator.userAgent.toLowerCase().indexOf("webtv/2.6") != -1) flashVer = 4;
	// WebTV 2.5 supports Flash 3
	else if (navigator.userAgent.toLowerCase().indexOf("webtv/2.5") != -1) flashVer = 3;
	// older WebTV supports Flash 2
	else if (navigator.userAgent.toLowerCase().indexOf("webtv") != -1) flashVer = 2;
	else if ( isIE && isWin && !isOpera ) {
		flashVer = ControlVersion();
	}	
	return flashVer;
}

// When called with reqMajorVer, reqMinorVer, reqRevision returns true if that version or greater is available
function DetectFlashVer(reqMajorVer, reqMinorVer, reqRevision)
{
	versionStr = GetSwfVer();
	if (versionStr == -1 ) {
		return false;
	} else if (versionStr != 0) {
		if(isIE && isWin && !isOpera) {
			// Given "WIN 2,0,0,11"
			tempArray         = versionStr.split(" "); 	// ["WIN", "2,0,0,11"]
			tempString        = tempArray[1];			// "2,0,0,11"
			versionArray      = tempString.split(",");	// ['2', '0', '0', '11']
		} else {
			versionArray      = versionStr.split(".");
		}
		var versionMajor      = versionArray[0];
		var versionMinor      = versionArray[1];
		var versionRevision   = versionArray[2];

        	// is the major.revision >= requested major.revision AND the minor version >= requested minor
		if (versionMajor > parseFloat(reqMajorVer)) {
			return true;
		} else if (versionMajor == parseFloat(reqMajorVer)) {
			if (versionMinor > parseFloat(reqMinorVer))
				return true;
			else if (versionMinor == parseFloat(reqMinorVer)) {
				if (versionRevision >= parseFloat(reqRevision))
					return true;
			}
		}
		return false;
	}
}

function AC_AddExtension(src, ext)
{
  if (src.indexOf('?') != -1)
    return src.replace(/\?/, ext+'?'); 
  else
    return src + ext;
}

function AC_Generateobj(objAttrs, params, embedAttrs) 
{ 
    var str = '';
    if (isIE && isWin && !isOpera)
    {
  		str += '<object ';
  		for (var i in objAttrs)
  			str += i + '="' + objAttrs[i] + '" ';
  		for (var i in params)
  			str += '><param name="' + i + '" value="' + params[i] + '" /> ';
  		str += '></object>';
    } else {
  		str += '<embed ';
  		for (var i in embedAttrs)
  			str += i + '="' + embedAttrs[i] + '" ';
  		str += '> </embed>';
    }

    document.write(str);
}

function AC_FL_RunContent(){
  var ret = 
    AC_GetArgs
    (  arguments, ".swf", "movie", "clsid:d27cdb6e-ae6d-11cf-96b8-444553540000"
     , "application/x-shockwave-flash"
    );
  AC_Generateobj(ret.objAttrs, ret.params, ret.embedAttrs);
}

function AC_GetArgs(args, ext, srcParamName, classid, mimeType){
  var ret = new Object();
  ret.embedAttrs = new Object();
  ret.params = new Object();
  ret.objAttrs = new Object();
  for (var i=0; i < args.length; i=i+2){
    var currArg = args[i].toLowerCase();    

    switch (currArg){	
      case "classid":
        break;
      case "pluginspage":
        ret.embedAttrs[args[i]] = args[i+1];
        break;
      case "src":
      case "movie":	
        args[i+1] = AC_AddExtension(args[i+1], ext);
        ret.embedAttrs["src"] = args[i+1];
        ret.params[srcParamName] = args[i+1];
        break;
      case "onafterupdate":
      case "onbeforeupdate":
      case "onblur":
      case "oncellchange":
      case "onclick":
      case "ondblClick":
      case "ondrag":
      case "ondragend":
      case "ondragenter":
      case "ondragleave":
      case "ondragover":
      case "ondrop":
      case "onfinish":
      case "onfocus":
      case "onhelp":
      case "onmousedown":
      case "onmouseup":
      case "onmouseover":
      case "onmousemove":
      case "onmouseout":
      case "onkeypress":
      case "onkeydown":
      case "onkeyup":
      case "onload":
      case "onlosecapture":
      case "onpropertychange":
      case "onreadystatechange":
      case "onrowsdelete":
      case "onrowenter":
      case "onrowexit":
      case "onrowsinserted":
      case "onstart":
      case "onscroll":
      case "onbeforeeditfocus":
      case "onactivate":
      case "onbeforedeactivate":
      case "ondeactivate":
      case "type":
      case "codebase":
        ret.objAttrs[args[i]] = args[i+1];
        break;
      case "id":
      case "width":
      case "height":
      case "align":
      case "vspace": 
      case "hspace":
      case "class":
      case "title":
      case "accesskey":
      case "name":
      case "tabindex":
        ret.embedAttrs[args[i]] = ret.objAttrs[args[i]] = args[i+1];
        break;
      default:
        ret.embedAttrs[args[i]] = ret.params[args[i]] = args[i+1];
    }
  }
  ret.objAttrs["classid"] = classid;
  if (mimeType) ret.embedAttrs["type"] = mimeType;
  return ret;
}

function createCookie(name,value,days) {
	if (days) {
		var date = new Date();
		date.setTime(date.getTime()+(days*24*60*60*1000));
		var expires = "; expires="+date.toGMTString();
	}
	else var expires = "";
	document.cookie = name+"="+value+expires+"; path=/";
}

function readCookie(name) {
	var nameEQ = name + "=";
	var ca = document.cookie.split(';');
	for(var i=0;i < ca.length;i++) {
		var c = ca[i];
		while (c.charAt(0)==' ') c = c.substring(1,c.length);
		if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
	}
	return null;
}

function eraseCookie(name) {
	createCookie(name,"",-1);
}

function checkRemember(){

	if(readCookie("iomnis-portal-login-save")){
		
		document.getElementById('save').checked = 'checked';
		
		var data = readCookie("iomnis-portal-login-save");
		
		var dat = data.split(",");
		
		document.getElementById('user').value = dat[0];
		document.getElementById('pass').value = dat[1];
		
		
	}

}

function saveLogin(){

	if(document.getElementById('save').checked){
		createCookie("iomnis-portal-login-save",document.getElementById('user').value+","+document.getElementById('pass').value,30);
	} else {
		eraseCookie("iomnis-portal-login-save");	
	}
	
}



