/*****************************************
Controllo della Partita I.V.A.
******************************************/

function controllaPIVA(pi)
{
	if( pi == '' )  return '';
	if( pi.length != 11 )
		return "La lunghezza della partita IVA non è\n" +
		"corretta: la partita IVA dovrebbe essere lunga\n" +
		"esattamente 11 caratteri.\n";
		
	validi = "0123456789";
	for( i = 0; i < 11; i++ ){
		if( validi.indexOf( pi.charAt(i) ) == -1 )
			return "La partita IVA contiene un carattere non valido \'" +
			pi.charAt(i) + 
			"\'.\nI caratteri validi sono le cifre.\n";
	}
	s = 0;
	for( i = 0; i <= 9; i += 2 )
		s += pi.charCodeAt(i) - '0'.charCodeAt(0);
	for( i = 1; i <= 9; i += 2 ){
		c = 2*( pi.charCodeAt(i) - '0'.charCodeAt(0) );
		if( c > 9 )  c = c - 9;
		s += c;
	}
	if( ( 10 - s%10 )%10 != pi.charCodeAt(10) - '0'.charCodeAt(0) )
		return "La partita IVA non è valida:\n" +
		"il codice di controllo non corrisponde.\n";

	return '';
}

/**************************************
Controllo del Codice Fiscale
***************************************/

function controllaCF(cf)
{
	var validi, i, s, set1, set2, setpari, setdisp;
	if( cf == '' )  return '';
	cf = cf.toUpperCase();
	if( cf.length != 16 )
		return "La lunghezza del codice fiscale non è\n" +
		"corretta: il codice fiscale dovrebbe essere lungo\n" +
		"esattamente 16 caratteri.\n";
		
	validi = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
	for( i = 0; i < 16; i++ ){
		if( validi.indexOf( cf.charAt(i) ) == -1 )
			return "Il codice fiscale contiene un carattere non valido \'" +
			cf.charAt(i) +
			"\'.\nI caratteri validi sono le lettere e le cifre.\n";
	}
	set1 = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
	set2 = "ABCDEFGHIJABCDEFGHIJKLMNOPQRSTUVWXYZ";
	setpari = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
	setdisp = "BAKPLCQDREVOSFTGUHMINJWZYX";
	s = 0;
	for( i = 1; i <= 13; i += 2 )
		s += setpari.indexOf( set2.charAt( set1.indexOf( cf.charAt(i) )));
	for( i = 0; i <= 14; i += 2 )
		s += setdisp.indexOf( set2.charAt( set1.indexOf( cf.charAt(i) )));
	if( s%26 != cf.charCodeAt(15)-'A'.charCodeAt(0) )
		return "Il codice fiscale non è corretto:\n" +
			   "il codice di controllo non corrisponde.\n";
			   
	return "";
}

/*****************************************
Controllo dell'email.
******************************************/
function controllaEmail(s) {
	var a = s.match(/^[\w-]+(\.[\w-]+)*@([\w-]+\.)+[a-zA-Z]{2,7}$/);
	if (a==null)
		return "La stringa non coindice con una email";
	if (a!=null && s.length<6)
		return "La stringa deve essere di almeno 6 caratteri";
	return "";
}

/*****************************************
Estrae l'elemento di una select che e'
stato selezionato
******************************************/
function isSelected(objForm, objName){
	var intLen = eval("document."+objForm+"."+objName+".length");
	for (i=0;i<intLen;i++) {
		if (eval("document."+objForm+"."+objName+"["+i+"].checked")) {
			return eval("document."+objForm+"."+objName+"["+i+"].value");
		}
	}
	return -1;
}
