//animate the opening of the branch (span.grower jQueryElement)
function openBranch(jQueryElement, noAnimation) {
		jQueryElement.addClass('OPEN').removeClass('CLOSE');
		if(noAnimation)
			jQueryElement.parent().find('ul:first').show();
		else
			jQueryElement.parent().find('ul:first').slideDown();
}
//animate the closing of the branch (span.grower jQueryElement)
function closeBranch(jQueryElement, noAnimation) {
	jQueryElement.addClass('CLOSE').removeClass('OPEN');
	if(noAnimation)
		jQueryElement.parent().find('ul:first').hide();
	else
		jQueryElement.parent().find('ul:first').slideUp();
}

//animate the closing or opening of the branch (ul jQueryElement)
function toggleBranch(jQueryElement, noAnimation) {
	if(jQueryElement.hasClass('OPEN'))
		closeBranch(jQueryElement, noAnimation);
	else{
		openBranch(jQueryElement, noAnimation);		
	}
}

//when the page is loaded...
$(document).ready(function () {	
	//to do not execute this script as much as it's called...
	if(!$('ul.tree.dhtml').hasClass('dynamized'))
	{
		//add growers to each ul.tree elements
		$('ul.tree.dhtml ul').prev().before("<span class='grower OPEN'> </span>");
		
		//dynamically add the '.last' class on each last item of a branch
		$('ul.tree.dhtml ul li:last-child, ul.tree.dhtml li:last-child').addClass('last');
		
		//collapse every expanded branch
		$('ul.tree.dhtml span.grower.OPEN').addClass('CLOSE').removeClass('OPEN').parent().find('ul:first').hide();
				
		$('ul.tree.dhtml > li > ul > li > ul.jcarousel-skin-tango').css("display","block");		
		$('ul.tree.dhtml > li > ul > li > span.grower').removeClass('CLOSE').addClass('OPEN');
		
		//open the tree for the selected branch
			$('ul.tree.dhtml .selected').parents().each( function() {
				if ($(this).is('ul'))
					toggleBranch($(this).prev().prev(), true);
			});
			toggleBranch( $('ul.tree.dhtml .selected').prev(), true);
		
		//add a fonction on clicks on growers
		$('ul.tree.dhtml span.grower').click(function(){
			toggleBranch($(this));
		});
		//mark this 'ul.tree' elements as already 'dynamized'
		$('ul.tree.dhtml').addClass('dynamized');

		$('ul.tree.dhtml').removeClass('dhtml');
	}
});

//when the page is loaded...   se hace un tratamiento especial al bloque de categorias de vino
$(document).ready(function () {	
	//to do not execute this script as much as it's called...
	if(!$('ul.tree.dhtml_special').hasClass('dynamized'))
	{
		//añadimos la acción de desplegar al enlace antes del ul
		$('ul.tree.dhtml_special ul li ul').prev().addClass('grower OPEN');
		
		//dynamically add the '.last' class on each last item of a branch
		$('ul.tree.dhtml_special ul li:last-child, ul.tree.dhtml li:last-child').addClass('last');
		
		//collapse every expanded branch
		$('ul.tree.dhtml_special a.grower.OPEN').addClass('CLOSE').removeClass('OPEN').parent().find('ul:first').hide();
				
		$('ul.tree.dhtml_special > li > ul > li > ul.jcarousel-skin-tango').css("display","block");		
		//$('ul.tree.dhtml_special > li > ul > li > a.grower').removeClass('CLOSE').addClass('OPEN');
		
		//open the tree for the selected branch
			$('ul.tree.dhtml_special .selected').parents().each( function() {
				if ($(this).is('ul'))
					toggleBranch($(this).prev(), true);
			});
			toggleBranch( $('ul.tree.dhtml_special .selected'), true);
		
		//add a fonction on clicks on growers
		$('ul.tree.dhtml_special a.grower').click(function(){
			toggleBranch($(this));
			if($(this).hasClass('selected')) return false;
		});
		//mark this 'ul.tree' elements as already 'dynamized'
		$('ul.tree.dhtml_special').addClass('dynamized');

		$('ul.tree.dhtml_special').removeClass('dhtml_special');
	}
	if(!$('a.grower').hasClass('OPEN'))
	{
		toggleBranch($('a.grower:first'),true);	
	}
});



