/*************************************************
	-- CALCOLO DELL'ALTEZZA DEL MAIN --
*************************************************/

debug_msg = false;

function toDebug(string)
{
	if (debug_msg)
	{
		if((typeof window.console=="undefined"))
		{			
			alert(string);
		}
		else
		{		
			 window.console.log(string);
		}
	}
}
   
function mainHeight()
{
	try 
		{
	//	inizializzazione delle variabili
		var main = $('main');
		var head = $('head');
		var colonnaSx = $('colonnaSx');
		var colonnaDx = $('colonnaDx');
		var container = $('container');
		var footer = $('footer');
		var head_text = $('head-text');
		var container_offsetHeight = container.offsetHeight;
		if($('frm_dettagli_richiesta')) container_offsetHeight += 350;		
		
		
		var altezza_comune = Math.max(colonnaSx.offsetHeight, Math.max(colonnaDx.offsetHeight, container_offsetHeight));
		if(altezza_comune < 400) altezza_comune = 400;
		var altezza_main = (head.offsetHeight) + altezza_comune + footer.offsetHeight;
		
	//	settaggi proporietà dei box contenitori
		colonnaSx.setStyle({'top':head.offsetHeight+'px','height':altezza_comune+'px'});
		container.setStyle({'top':head.offsetHeight+'px','height':altezza_comune+'px'});
		colonnaDx.setStyle({'top':head.offsetHeight+'px','height':altezza_comune+'px'});
		footer.setStyle({'top':head.offsetHeight+altezza_comune+'px'});
		head_text.setStyle({'top':altezza_main+10 + 'px', 'left': main.offsetLeft+'px'});
		main.setStyle({'height': altezza_main + 'px'});
	
		//pulizia del contenuto: eliminazione dell' utlimo paragrafo vuoto
		if($('contenuto'))
		{
			
			var discendenti = $('contenuto').immediateDescendants();
							
			var discendenti_p = discendenti.findAll(
					function(n) { if (n.nodeName == 'P') return n; }
					);
	
			var k = discendenti_p.size() - 1;
	
			if(discendenti_p[k].empty() || discendenti_p[k].innerHTML == "\n&nbsp;\n" || discendenti_p[k].innerHTML == "&nbsp; ")
			{
				discendenti_p[k].remove();
			}
		}
		
		var immagini = $$('#container img');
		var style_float;
		immagini.each(function(img)
		{
			if(img.getStyle('float') == 'left') img.setStyle({'margin':'0px 10px 0px 0px'});
			if(img.getStyle('float') == 'right') img.setStyle({'margin':'0px 0px 0px 10px'});
		});
		

		
	}
	catch(e) 
	{ 
		toDebug(e.toString());
	}
}



function tableBg(el)
{
	try 
	{
		var righe = $$('#'+el+' tr');
		
		for (var i=0;i<righe.length;i++)
		{
			
			if(i%2 == 0) righe[i].setStyle({'background':'#E8F3FF'});
			else righe[i].setStyle({'background':'#D3E7FF'});
			if(i == 0) righe[0].setStyle({'background':'#43A2F2', 'color': '#FFFFFF'});
		}
	}
	catch(e) 
	{ 
		toDebug(e.toString());
	}
}


/*BOF FORM CONTATTI*/

//restituisco true in caso di errore
function validateFormElement(elem)
{
	if(elem.value=="")
	{
		errorOnFormElement(elem);
		return true;
	}
	else 
	{
		return false;
	}
}


function validateHiddenElement(element)
{
	if(validateFormElement(element))
	{
		errorOnFormElement('fieldset_dettagli_richiesta');
		errorOnFormElement('fieldset_dettagli_preventivo');
		return true;
	}
	else return false;



}

function validateCheckBoxElement(elem)
{
	if(elem.checked)
	{
		return false;
	}
	else
	{
		errorOnFormElement(elem.parentNode);	
		return true;
	}
}

function validateFormEmail(elem)
{
	var emailRegexp = RegExp('^[A-Za-z0-9._-]+[@]([A-Za-z0-9-]+[.])+([A-za-z]{2,4})$', 'i');
	
	if (emailRegexp.test(elem.value))
	{
		return false;
	}
	else
	{
		errorOnFormElement(elem);
		return true;
	}
}


function errorOnFormElement(elem)
{
	Effect.Shake(elem);
	new Effect.Highlight(elem);
}


function submitGuestBook()
{
	var d = new Date()
	param = d.getTime();
		
	var form = $('guestbooksign');
	document.forms['guestbooksign'].secure.value = param;


	//copio testo della text area
	if (document.forms['guestbooksign'].frm_tipo_richiesta.value=="richiesta preventivo")
	{
		document.forms['guestbooksign'].frm_messaggio.value=document.forms['guestbooksign'].frm_messaggio_a.value;
	}
	else
	{
		document.forms['guestbooksign'].frm_messaggio.value=document.forms['guestbooksign'].frm_messaggio_b.value;	
	}

//inizio validazione
	var error_found = 0;
			
	if(validateFormElement(form.frm_nome)) error_found++;
	if(validateFormEmail(form.frm_email)) error_found++;
	if(validateFormElement(form.frm_telefono)) error_found++;
	if(validateCheckBoxElement(form.frm_privacy_a) && validateCheckBoxElement(form.frm_privacy_b)) error_found++;
	//if(validateHiddenElement(form.frm_tipo_richiesta)) error_found++;
//fine validazione	


	if(error_found==0)
	{
		Effect.BlindUp('form_email_all_fields');

		form.request({
		
		  onComplete: function()
		  { 	
			Effect.BlindDown('form_email_thanks');
			Form.reset('guestbooksign');

			  return false; 
		   }
		
		});

/*
	document.forms['guestbooksign'].submit();		
*/	
	}	
	return false;
}



function showOnClick(element)
{
	
	if($(element).style.display == '') return false;
	else
	{
		if(element == 'frm_dettagli_richiesta')
		{
			Effect.BlindUp($('frm_dettagli_preventivo'), {afterFinish: down=function()
			{
				Effect.BlindDown(element, {afterFinish: down2=function()
				{
				
				}
				});				
												
				document.forms['guestbooksign'].frm_tipo_richiesta.value = 'richiesta informazioni';				
				
			}});
		}
		else
		{
			Effect.BlindUp($('frm_dettagli_richiesta'), {afterFinish: down=function()
			{
				Effect.BlindDown($('frm_dettagli_preventivo'), {afterFinish: down2=function()
				{
							
				}
				});
				document.forms['guestbooksign'].frm_tipo_richiesta.value = 'richiesta preventivo';
				
			}});
		}
	}
	
}

/*EOF FORM CONTATTI*/



/* BOF SCROLL DEI BOX */

var timer;
var moving = false;
var element_to_move;
var max_move;


function scrollingContent(el, clipHeight)
{
	var element = $(el);
	var element_dimension = element.getDimensions();
	var clip_element = element.up();
	var clip_dimension = clip_element.getDimensions();
	var scroll_container = clip_element.up();

	clip_element.setStyle({'clip': 'rect(0px,'+clip_dimension.width+'px,'+clipHeight+'px,0px)'});
	if(element_dimension.height > clipHeight)
	{
		var goUp = $$('#'+scroll_container.id+' .goUp')[0];
		var goDown = $$('#'+scroll_container.id+' .goDown')[0];
		var down_top = scroll_container.offsetHeight - goDown.offsetHeight;
		// settaggi freccia in alto
		goUp.setStyle({
			'top': '30px',
			'cursor': 'pointer'
		});
		goUp.onmouseover =function()
		{
			element_to_move = element;
			max_move = clipHeight;
			scrollUp();
		};
		goUp.onmouseout = function()
		{
			
			moving = false;
			clearTimeout(timer);
		}
		goUp.show();
		
		
		// settaggi per freccia in basso
		goDown.setStyle({
			'top': '50px',
			'cursor': 'pointer'
		});
		goDown.onmouseover =function()
		{
			element_to_move = element;
			max_move = clipHeight;
			scrollDown();

		};
		goDown.onmouseout = function()
		{
			moving = false;
			clearTimeout(timer);
		}
		
		goDown.show();
	}
	
}

function scrollUp()
{	
	if(element_to_move)
	{
		if(element_to_move.offsetTop>=0) return false;
		moving = true;
		new Effect.Move(element_to_move,{x:0,y:1, duration: 0.01});
		if(moving) timer = setTimeout(scrollUp,10);
		else return false;
	}
	return false;
}
function scrollDown()
{
	if(element_to_move)
	{
		if(element_to_move.offsetTop < -(element_to_move.offsetHeight - max_move)) return false;
		moving = true;
		new Effect.Move(element_to_move,{x:0,y:-1, duration: 0.01});
		if(moving) timer = setTimeout(scrollDown,10);
		else return false;
	}
	return false;
}


function toggleMenu(menu, toggler, disappear, toggler2)
{
	try
	{
		var menu = $(menu);
		var toggler = $(toggler);
		if(disappear) var disappear = $(disappear);
		if(toggler2) var toggler2 = $(toggler2);
		
		var figli_array = menu.descendants();
		var active = false;
		figli_array.each(function(el)
		{
			if(el.className.match('active')) active = true;
		});
		
		toggler.setStyle({'cursor':'pointer'});
		if(!active) menu.hide();
		if(active && disappear) disappear.hide();
		
		
		toggler.onclick = function()
		{
			if(disappear && (disappear.getStyle('display') == 'block' || disappear.getStyle('display') == ''))
			{
				Effect.SwitchOff(disappear,{afterFinish:function()
				{
					Effect.toggle(menu, 'blind');
				}});
			}
			else if(disappear &&  disappear.getStyle('display') == 'none')
			{
				Effect.toggle(menu, 'blind',{afterFinish:function()
				{
					Effect.BlindDown(disappear);
				}});
			}
			else Effect.toggle(menu, 'blind');
			//closeAll(menu, toggler);
		}
		
		if(toggler2)
		{
			toggler2.setStyle({'cursor':'pointer'});
			toggler2.onclick = function()
			{
				if(disappear && (disappear.getStyle('display') == 'block' || disappear.getStyle('display') == ''))
				{
					Effect.SwitchOff(disappear,{afterFinish:function()
					{
						Effect.toggle(menu, 'blind');
					}});
				}
				else if(disappear &&  disappear.getStyle('display') == 'none')
				{
					toggler2.onclick = function(){alert('ciao');}
					Effect.toggle(menu, 'blind',{afterFinish:function()
					{
						Effect.BlindDown(disappear);
					}});
				}
				else Effect.toggle(menu, 'blind');
				
				//closeAll(menu, toggler2);
			}
		}
	}
	catch(e)
	{
		toDebug(e.toString());
	}
}




function closeAll(opened, toggler)
{
try
{
	var boxes = new Array();
	boxes[0] = 'offerte-famiglia';
	boxes[1] = 'offerte-parchi';
	boxes[2] = 'offerte-entroterra';
	boxes.each(function(el)
	{
		alert(el + ', '+toggler.id); 
		el = Element.extend(el);
		if(el != opened.id && (Element.getStyle(el, 'overflow') == 'visible' || Element.getStyle(el, 'display') == ''))
		Effect.BlindUp(el,{afterFinish: showToggler = function()
		{
			if(Element.getStyle(el, 'overflow') == 'visible' || Element.getStyle(el,'display') == 'none') Effect.toggle(toggler,'blind');
		}});
	
	});
}
catch(e)
	{
		toDebug(e.toString());
	}
}




function replaceFlash()
{
	sIFR.replace(agency, 
	{
		selector: '#colonnaSx h2',
		css: [
			'.sIFR-root {font-size: 21px;color: #330000;}'
		],
		filters: [
			'DropShadow{knockout: false,distance: 5,color: \'#330000\',strength: 0.5}'
		]
	});
	sIFR.replace(agency, 
	{
		selector: '#briciole',
		css: [
			'.sIFR-root {font-size: 20px;color: #ffffff;font-weight: bold;}'
		],
		filters: [
			'DropShadow{knockout: false,distance: 5,color: \'#330000\',strength: 0.5}'
		]
	});
	sIFR.replace(agency, 
	{
		selector: '#titolo-offerte',
		css: [
			'.sIFR-root {font-size: 20px;color: #ffffff;font-weight: bold;}'
		],
		filters: [
			'DropShadow{knockout: false,distance: 5,color: \'#330000\',strength: 0.5}'
		]
	});
	sIFR.replace(agency, 
	{
		selector: '#colonnaDx h2',
		css: [
			'.sIFR-root {font-size: 20px;color: #ffffff;font-weight: bold;}'
		],
		onRollOver: [
			'.sIFR-root {font-size: 20px;color: #ffffff;font-weight: bold;cursor: pointer;}'
		],
		filters: [
			'DropShadow{knockout: false,distance: 5,color: \'#330000\',strength: 0.5}'
		]
	});
	sIFR.replace(agency, 
	{
		selector: '.localita h2',
		css: [
			'.sIFR-root {font-size: 22px;color: #003366;font-weight: bold;}'
		],
		filters: [
			'DropShadow{knockout: false,distance: 5,color: \'#330000\',strength: 0.5}'
		]
	});
	sIFR.replace(agency, 
	{
		selector: '.box-head h2',
		css: [
			'.sIFR-root {font-size: 22px;color: #ffffff;}'
		]
	});
}

/* EOF SCROLL DEI BOX */

/*************************************************
	-- RICHIAMO TUTTO UNA UNICA FUHNZIONE --
*************************************************/


function allFunctions() 
{
	replaceFlash();
	//toggleMenu('offerte-famiglia', 'bottone-famiglia-link', 'immagine-famiglia', 'immagine-famiglia');
	mainHeight();
	//toggleMenu('offerte-parchi', 'bottone-parchi-link', 'immagine-parchi', 'immagine-parchi');
	//toggleMenu('offerte-entroterra', 'bottone-entroterra-link', 'immagine-entroterra', 'immagine-entroterra');

	//toggleMenu('newsletter', 'bottone-newsletter-link');
	

	$('page_loading').hide();
	
}


if (window.attachEvent)	window.attachEvent("onload", allFunctions);
else window.onload=allFunctions;