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 MM_showHideLayers() { //v6.0
  var i,p,v,obj,args=MM_showHideLayers.arguments;
  for (i=0; i<(args.length-2); i+=3) if ((obj=MM_findObj(args[i]))!=null) { v=args[i+2];
    if (obj.style) { obj=obj.style; v=(v=='show')?'visible':(v=='hide')?'hidden':v; }
    obj.visibility=v; }
}

// *************************************************
// Verifica i dati nella pagina di richiesta offerta
// *************************************************
function VerificaDati(Form) 
{
	var msg="";
	var ChOBL = false;

	for(i=0; i<Form.length-1; i++) 
	{
		var Elem = Form.elements[i];
		switch (Elem.id) 
		{	case "testo": 
				break;
			case "testoOBL":
				if (Elem.value == "")
				{	msg = "Attenzione. Alcuni campi obligatori sono stati omessi.";
				}
				break;
			case "testoOBLch": 
				switch (Elem.name)
				{	case "APPLIC_altroTXT": 
						if (findObj("APPLIC_altro").checked==true && Elem.value == "")
						{	msg="Attenzione. ALTRA APPLICAZIONE selezionata. \n Riempire il campo.";}
						break;
					case "TOOLHOLDER_taperTXT": 
						if (findObj("TOOLHOLDER_taper").checked==true && Elem.value == "")
						{	msg="Attenzione. Tool Holder TAPER selezionato. \n Riempire il campo.";	}
						break;
					case "TOOLHOLDER_hskTXT": 
						if (findObj("TOOLHOLDER_hsk").checked==true && Elem.value == "")
						{	msg="Attenzione. Tool Holder HSK selezionato. \n Riempire il campo.";	}
						break;
					case "TOOLHOLDER_vdiTXT": 
						if (findObj("TOOLHOLDER_vdi").checked==true && Elem.value == "")
						{	msg="Attenzione. Tool Holder VDI selezionato. \n Riempire il campo.";	}
						break;
					case "TOOLHOLDER_altroTXT": 
						if (findObj("TOOLHOLDER_altro").checked==true && Elem.value == "")
						{	msg="Attenzione. ALTRO Tool Holder selezionato. \n Riempire il campo.";	}
						break;/**/
				}
				break;
    		case "email": 
				if(Elem.value!="")
				{	if(Elem.value.indexOf("@")==-1)
					{	msg = "Il campo E-Mail deve contenere una email valida.";
					}
				}
				break;
			case "emailOBL":
				if(Elem.value!="")
				{	if(Elem.value.indexOf("@")==-1)
					{	msg = "Il campo E-Mail deve contenere una email valida.";
					}
				}
				else
				{	msg = "Attenzione. Inserire l'e-mail.";
				}
				break;
			case "numero": 
				if(Elem.value!="")
				{	var v=parseFloat(Elem.value)
					if(isNaN(v)) 
					{  	msg = "Uno o pių campi non contengono numeri. \n Controllare Diametro massimo o Lunghezza massima.";
					}
				}
				break;
			case "numeroOBL": 
				if(Elem.value!="")
				{	var v=parseFloat(Elem.value)
					if(isNaN(v)) 
					{  	msg = "Uno o pių campi non contengono numeri. \n Controllare Diametro massimo o Lunghezza massima.";
			 		}
				}
				else
				{	msg = "Attenzione. Alcuni campi obligatori sono stati omessi.";	
				}
				break;
			case "check": 
				break;
			case "checkOBLAppl":
				if (Elem.checked==true)
				{	ChOBL = true; }
				break;
		}
	}
	
	if (ChOBL == false)
	{	msg = "Attenzione. Scegliere almeno un'applicazione.";
	}
	//Se non ci sono errori tutto OK
 	if(msg=="")	return true;
	//if(msg=="")	msg="OK!!!";
	alert(msg);
	return false;
}

function VerificaDatiInfo(Form) 
{
	var msg="";

	for(i=0; i<Form.length-1; i++) 
	{
		var Elem = Form.elements[i];
		switch (Elem.id) 
		{	case "testoOBL":
				if (Elem.value == "")
				{	msg = "Attenzione. Alcuni campi obligatori sono stati omessi.";
				}
				break;
			case "emailOBL":
				if(Elem.value!="")
				{	if(Elem.value.indexOf("@")==-1)
					{	msg = "Il campo E-Mail deve contenere una email valida.";
					}
				}
				else
				{	msg = "Attenzione. Alcuni campi obligatori sono stati omessi.";
				}
				break;
		}
	}
	
	//Se non ci sono errori tutto OK
 	if(msg=="")	return true;
	//if(msg=="")	msg="OK!!!";
	alert(msg);
	return false;
}

function VerificaDatiServ(Form) 
{
	var msg="";
	var ChOBL = false;
	
	for(i=0; i<Form.length-1; i++) 
	{
		var Elem = Form.elements[i];
		switch (Elem.id) 
		{	case "testoOBL":
				if (Elem.value == "")
				{	msg = "Attenzione. Alcuni campi obligatori sono stati omessi.";
				}
				break;
			case "emailOBL":
				if(Elem.value!="")
				{	if(Elem.value.indexOf("@")==-1)
					{	msg = "Il campo E-Mail deve contenere una email valida.";
					}
				}
				else
				{	msg = "Attenzione. Alcuni campi obligatori sono stati omessi.";
				}
				break;
			case "testoOBLch": 
				switch (Elem.name)
				{	case "SERV_altroTXT": 
						if (findObj("SERV_altro").checked==true && Elem.value == "")
						{	msg="Attenzione. ALTRO SERVIZIO selezionato. \n Riempire il campo.";}
						break;
				}
				break;
			case "checkOBLServ":
				if (Elem.checked==true)
				{	ChOBL = true; }
				break;
		}
	}
	
	if (ChOBL == false)
	{	msg = "Attenzione. Richiedere almeno un servizio.";
	}
	//Se non ci sono errori tutto OK
 	if(msg=="")	return true;
	//if(msg=="")	msg="OK!!!";
	alert(msg);
	return false;
}

function VerificaDatiLicenza(Form) 
{
	var msg="";

	for(i=0; i<Form.length-1; i++) 
	{
		var Elem = Form.elements[i];
		
		if(Elem.disabled == false)
		{
			switch (Elem.id) 
			{	case "testoOBL":
					if (Elem.value == "")
					{	msg = "Attenzione. Alcuni campi obligatori sono stati omessi. " + Elem.title;
					}
					break;
				case "emailOBL":
					if(Elem.value!="")
					{	if(Elem.value.indexOf("@")==-1)
						{	msg = "Il campo E-Mail deve contenere una email valida. " + Elem.title;
						}
					}
					else
					{	msg = "Attenzione. Alcuni campi obligatori sono stati omessi. " + Elem.title;
					}
					break;
				case "numero": 
					if(Elem.value!="")
					{	var v=parseFloat(Elem.value)
						if(isNaN(v)) 
						{  	Elem.value = Val(Elem.value);
						}
					}
					break;
				case "numeroOBL": 
					if(Elem.value!="")
					{	var v=parseFloat(Elem.value)
						if(isNaN(v)) 
						{  	Elem.value = Val(Elem.value);
						}
					}
					else
					{	msg = "Attenzione. Alcuni campi obligatori sono stati omessi. " + Elem.title;
					}
					break;
			}
		}
	}
	
	//Se non ci sono errori tutto OK
 	if(msg=="")	return true;
	//if(msg=="")	msg="OK!!!";
	alert(msg);
	return false;
}

function Ritorno()
{
	var msg="";
	
	var Giorni=0;
	
	NMacc = findObj("NumMacc").value;
	Ore = findObj("OreTurno").value;
	Turni = findObj("NumTurni").value;
	VMandrino = findObj("ValMand").value;
	VPres = findObj("ValMacc").value;
	
	if (NMacc != "")
	{	var v=parseFloat(NMacc);
		if(isNaN(v)) msg = "Inserire solo numeri.";
	}
	else
	{	msg = "Attenzione. Inserire tutti i campi.";
	}
	
	if (Ore != "")
	{	var v=parseFloat(Ore);
		if(isNaN(v)) msg = "Inserire solo numeri.";
	}
	else
	{	msg = "Attenzione. Prezzo macchina di Presetting non settato.";
	}
	
	if (Turni != "")
	{	var v=parseFloat(Turni);
		if(isNaN(v)) msg = "Inserire solo numeri.";
	}
	else
	{	msg = "Attenzione. Inserire tutti i campi.";
	}
	
	if (VMandrino != "")
	{	var v=parseFloat(VMandrino);
		if(isNaN(v)) msg = "Inserire solo numeri.";
	}
	else
	{	msg = "Attenzione. Inserire tutti i campi.";
	}
	
	if (VPres != "")
	{	var v=parseFloat(VPres);
		if(isNaN(v)) msg = "Inserire solo numeri.";
	}
	else
	{	msg = "Attenzione. Inserire tutti i campi.";
	}
	
	if (msg != "")
	{	alert(msg);
	}
	else
	{ 	Giorni = VPres/(((NMacc*Ore)*Turni)*VMandrino);
		findObj("Risult").value = Math.floor(Giorni);
	}
	
}

// Example: obj = findObj("image1");
function findObj(theObj, theDoc)
{
  var p, i, foundObj;
  
  if(!theDoc) theDoc = document;
  if( (p = theObj.indexOf("?")) > 0 && parent.frames.length)
  {
    theDoc = parent.frames[theObj.substring(p+1)].document;
    theObj = theObj.substring(0,p);
  }
  if(!(foundObj = theDoc[theObj]) && theDoc.all) foundObj = theDoc.all[theObj];
  for (i=0; !foundObj && i < theDoc.forms.length; i++) 
    foundObj = theDoc.forms[i][theObj];
  for(i=0; !foundObj && theDoc.layers && i < theDoc.layers.length; i++) 
    foundObj = findObj(theObj,theDoc.layers[i].document);
  if(!foundObj && document.getElementByName) foundObj = document.getElementByName(theObj);
  
  return foundObj;
}

var popUpWin=0;
function popUpWindow(URLStr, left, top, width, height)
{
  if(popUpWin)
  {    if(!popUpWin.closed) popUpWin.close();  }

  popUpWin = open(URLStr, 'popUpWin', 'toolbar=no,location=no,directories=no,status=no,menubar=no,scrollbars=yes,resizable=yes,copyhistory=yes,width='+width+',height='+height+',left='+left+', top='+top+',screenX='+left+',screenY='+top+'');

}

function countdown(Obj){
	iniData= new Date(2009,9,6,9,0,0); // data inizio sequenza mesi-1 es. set=8
	oggi= new Date();
	//oggi.setHours(1,1,1,0) ;
	iniDataIt=iniData.getDate()+'-'+(iniData.getMonth()+1)+'-'+iniData.getFullYear()+' '+iniData.getHours()+':'+iniData.getMinutes()+':'+iniData.getSeconds();
	milDif=(iniData-oggi)
	giorni=parseInt(milDif/86400000);  
	milDif=milDif-(giorni*86400000); //millisecondi restanti talti i giorni
	ore=parseInt(milDif/3600000);
	milDif=milDif-(ore*3600000); //millisecondi restanti talti i giorni
	minuti=parseInt(milDif/60000);
	milDif=milDif-(minuti*60000); //millisecondi restanti talti i giorni
	secondi=parseInt(milDif/1000);
	milDif=milDif-(secondi*1000); //millisecondi restanti talti i giorni
	testo = giorni+' giorni, '+ore+':'+minuti+':'+secondi;
	//alert(testo); //commentare
	//return testo
	var div = MM_findObj("countdown");
	div.innerHTML = testo;
	setTimeout("countdown()",1000)
}

function Val(text, def)
{
	if(text == "") return "";
	if(text == "0") return def;
	
	myF = parseInt(text);
	if(isNaN(myF))
	{	myF = 1;
	}
	return myF;
}

function TestInputFile(objFile, filters)
{	
	var fileName = objFile.value
	if(fileName == '') 
	{	return '';
	}
	
	var myFilters = filters.split(',');
	
	//Ottengo l'estensione del file
	var parts = fileName.split('.');
	var ext = parts[parts.length-1];
	
	//Testo tutte le estensioni
	var trovato = false;
	for (var i=0; i<myFilters.length; i++) 
	{	
		if(ext.toUpperCase() == myFilters[i].toUpperCase())
		{	trovato = true;
			break;
		}
	}
	
	if(trovato == false)
	{	alert('Il file selezionato non č del tipo richiesto.');
		objFile.value = '';
	}
}