/*===================================================================*/
/*		TIMERS														 */
/*===================================================================*/
jQuery.fn.extend({
	everyTime: function(interval, label, fn, times, belay) {
		return this.each(function() {
			jQuery.timer.add(this, interval, label, fn, times, belay);
		});
	},
	oneTime: function(interval, label, fn) {
		return this.each(function() {
			jQuery.timer.add(this, interval, label, fn, 1);
		});
	},
	stopTime: function(label, fn) {
		return this.each(function() {
			jQuery.timer.remove(this, label, fn);
		});
	}
});

jQuery.extend({
	timer: {
		guid: 1,
		global: {},
		regex: /^([0-9]+)\s*(.*s)?$/,
		powers: {
			// Yeah this is major overkill...
			'ms': 1,
			'cs': 10,
			'ds': 100,
			's': 1000,
			'das': 10000,
			'hs': 100000,
			'ks': 1000000
		},
		timeParse: function(value) {
			if (value == undefined || value == null)
				return null;
			var result = this.regex.exec(jQuery.trim(value.toString()));
			if (result[2]) {
				var num = parseInt(result[1], 10);
				var mult = this.powers[result[2]] || 1;
				return num * mult;
			} else {
				return value;
			}
		},
		add: function(element, interval, label, fn, times, belay) {
			var counter = 0;
			
			if (jQuery.isFunction(label)) {
				if (!times) 
					times = fn;
				fn = label;
				label = interval;
			}
			
			interval = jQuery.timer.timeParse(interval);

			if (typeof interval != 'number' || isNaN(interval) || interval <= 0)
				return;

			if (times && times.constructor != Number) {
				belay = !!times;
				times = 0;
			}
			
			times = times || 0;
			belay = belay || false;
			
			if (!element.$timers) 
				element.$timers = {};
			
			if (!element.$timers[label])
				element.$timers[label] = {};
			
			fn.$timerID = fn.$timerID || this.guid++;
			
			var handler = function() {
				if (belay && this.inProgress) 
					return;
				this.inProgress = true;
				if ((++counter > times && times !== 0) || fn.call(element, counter) === false)
					jQuery.timer.remove(element, label, fn);
				this.inProgress = false;
			};
			
			handler.$timerID = fn.$timerID;
			
			if (!element.$timers[label][fn.$timerID]) 
				element.$timers[label][fn.$timerID] = window.setInterval(handler,interval);
			
			if ( !this.global[label] )
				this.global[label] = [];
			this.global[label].push( element );
			
		},
		remove: function(element, label, fn) {
			var timers = element.$timers, ret;
			
			if ( timers ) {
				
				if (!label) {
					for ( label in timers )
						this.remove(element, label, fn);
				} else if ( timers[label] ) {
					if ( fn ) {
						if ( fn.$timerID ) {
							window.clearInterval(timers[label][fn.$timerID]);
							delete timers[label][fn.$timerID];
						}
					} else {
						for ( var fn in timers[label] ) {
							window.clearInterval(timers[label][fn]);
							delete timers[label][fn];
						}
					}
					
					for ( ret in timers[label] ) break;
					if ( !ret ) {
						ret = null;
						delete timers[label];
					}
				}
				
				for ( ret in timers ) break;
				if ( !ret ) 
					element.$timers = null;
			}
		}
	}
});

if (jQuery.browser.msie)
	jQuery(window).one("unload", function() {
		var global = jQuery.timer.global;
		for ( var label in global ) {
			var els = global[label], i = els.length;
			while ( --i )
				jQuery.timer.remove(els[i], label);
		}
	});
/*===================================================================*/
/*		SLIDER														 */
/*===================================================================*/
function sliderRotate() {
	var src_main=$("#slider img:first-child").attr('src');
	title_main=$("#slider img:first-child").attr('title');
	var src_1=$("#slider #thumb_1 img").attr('src');
	var title_1=$("#slider #thumb_1 img").attr('title');
	var src_2=$("#slider #thumb_2 img").attr('src');
	var title_2=$("#slider #thumb_2 img").attr('title');
	var parseTitle=title_1.split(',');
	
	//t1->main
	$("#slider img:first-child").before('<img src="'+src_1+'" title="'+title_1+'""/>');	
	//t2->t1
	$("#slider #thumb_1 img").attr('src', src_2);
	$("#slider #thumb_1 img").attr('title', title_2);
	//main->t2
	$("#slider #thumb_2 img").attr('src', src_main);
	$("#slider #thumb_2 img").attr('title', title_main);
	//
	//console.log(src_swap+' '+title_swap);
	$('#slider>img:nth-child(2)').animate({
		top: ['-320px', 'swing']
	}, 500, function() {
		$('#slider img:nth-child(2)').remove();
		$('#slider .caption').html(parseTitle[0]);
		$('#slider .subcaption').html(parseTitle[1]);
	}
);


}

/*===================================================================*/
/*		READY														 */
/*===================================================================*/
       
   $(document).ready(function() {
							  
							  
		// -----------------------------------------
		// 		SLIDER
		// -----------------------------------------
		$('#slider').mouseover(function(){
			$('#slider_bar').show();
		});
		$('#slider').mouseleave(function(){
			$('#slider_bar').hide();
		});
		$('#slider_bar .thumb').mouseover(function(){
			$(this).removeClass('semitransparent');
		});
		$('#slider_bar .thumb').mouseleave(function(){
			$(this).addClass('semitransparent');
		});
		
		$('#slider').click(function(){
			var parseSrc=$("#slider img:first-child").attr('src').split('/');
			var title=$("#slider img:first-child").attr('title').replace(/ /g,"_");;

			window.location.href='it/estates/'+title+'/'+parseSrc[1]+'.html';
		});
		
		var title_main=$("#slider img:first-child").attr('title');
		var parseTitle=title_main.split(',');
		$('#slider .caption').html(parseTitle[0]);
		$('#slider .subcaption').html(parseTitle[1]);
		
		$(document).everyTime(10000, function(i) {
			sliderRotate();
		},30);
		
		// --- ACCORDION ---
		var obj=$('#accordion');
		$('div',obj).hide();
		$('.sub1',obj).show();
		$('a',obj).click(function(){
			
			var node=$(this).parent();
			var parent=$(this).parent().parent().parent();
			var level=Number($(node).parent().attr('class').substr(3,1));
			var next_level=level+1;
			
			$('a',obj).removeClass('active');
			$(this).addClass('active');
			$('.sub'+next_level,node).addClass('open');
			$('.sub'+next_level,parent).not('.open').hide('fast');
			$('.sub'+next_level,node).removeClass('open');
			$('.sub'+level+' a').removeClass('collapsible');
	
			$('.sub'+next_level,node).toggle('fast');
			$(this).toggleClass('collapsible');
			return false;
		
		});

	});
		
