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);
		}
	});



jQuery(document).ready(function(){
	 jQuery('.imagetile img').each(function(){
		sp = jQuery(this).parent().parent().attr('speed');
		settime(sp,jQuery(this).attr('id'));
	 });
	 
	 setInterval(function() {
        jQuery('#imageRotator').each(function(){
			max = parseInt(jQuery('#imageRotatorImages').children().size())
			num = parseInt(jQuery(this).attr('currentImage'))
			if (num==max) {
				num=1;
			} else {
				num+=1;
			}
			src = jQuery('#img' + num).attr('value')
			html = "<img src='" + src + "' />"
			jQuery(this).fadeOut(500, function(){
				jQuery(this).html("")
				jQuery(this).html(html).fadeIn(500);	
			});
			jQuery(this).attr('currentImage',num)
			});
     },5000);

	 
	 
	 // Image hover transparency effect
	 
	 jQuery('.hoverTrans a').hover(function(){
	 		jQuery(this).parent().parent().addClass('transparentClass'); 
	 }, function(){
	 		jQuery(this).parent().parent().removeClass('transparentClass');
	 }
	 );
	 
	 jQuery('.shopProduct img').hover(function(){
	 		jQuery(this).addClass('transparentClass'); 
	 }, function(){
	 		jQuery(this).removeClass('transparentClass');
	 }
	 );
	 
	 jQuery('.imagetile img').hover(function(){
	 		jQuery(this).addClass('transparentClass'); 
	 }, function(){
	 		jQuery(this).removeClass('transparentClass');
	 }
	 );
	 
	 jQuery('.cartDiv a').hover(function(){
	 	jQuery('.cartDiv').addClass('transparentClass');
	 }, function(){
	 	jQuery('.cartDiv').removeClass('transparentClass');
	 });
	 
	 
	 jQuery('.galleryImage img').hover(function(){
	 		jQuery(this).addClass('transparentClass'); 
	 }, function(){
	 		jQuery(this).removeClass('transparentClass');
	 }
	 );
	 jQuery('.product_image').hover(function(){
	 		jQuery(this).addClass('transparentClass'); 
	 }, function(){
	 		jQuery(this).removeClass('transparentClass');
	 }
	 );
	 jQuery('.manufact img').hover(function(){
	 		jQuery(this).addClass('transparentClass'); 
	 }, function(){
	 		jQuery(this).removeClass('transparentClass');
	 }
	 );



     jQuery('#nav li').mouseenter(function(){
	 	jQuery("ul",this).fadeIn(0);
	 }).mouseleave(function(){
	 	jQuery("ul",this).fadeOut(200);
	 });



	// zoom in bike log behind image tiles and then fade out
	jQuery('.bikelogo img').load(function(){
			jQuery(this).animate({
				height:"388px",
				width:"430px",
				top: "0px"
			}, 9000);
		});


	 //  Swap href for Bikes and Helmets pages since only the sub menus should be clickable
	 jQuery('#nav li ul').each(function(){
	 	jQuery(this).parent().each(function(){
			jQuery('a:first', this).attr('href','#');
		});
	 });
	  
	
	 // Rotate quote on home page
	  
	 jQuery('#quote').everyTime(10000, 'controlled', function() {
								jQuery(this).fadeOut("slow", function(){
									jQuery(this).html(getRandomQuote(jQuery(this).text));
									jQuery(this).fadeIn("slow");	
									});
								});
	
	
	// Manufacturer Hover zoom effect
/*								
	jQuery('.manufact img').each(function(){
		jQuery(this).hover(function(){
			jQuery(this).animate({
				height:"85px",
				width:"85px"
			}, 400);
		},function(){
			jQuery(this).animate({
				height:"65px",
				width:"65px"
			}, 400);
		});
		
	});
*/

});

function getRandomQuote(currentText){
	var randomInt = Math.floor(Math.random()*5);
	var quote = "<a href='http://prod.tykerider.com/learn-more'>";
	
	switch(randomInt){
		case 0:
			quote += "'The perfect way to introduce your child to the art of riding a bike…born to be wild.' – The Telegraph";
			break;
		case 1:
			quote += "'This has to be the coolest bike on the market' - Junior Magazine";
			break;
		case 2:
		    quote += "'The coolest learner bike around.' - James Beechinor-Collins, Editor in Chief, T3 Magazine";
			break;
		case 3:
			quote += "'The journey to the nursery just got cooler.' - Junior Magazine";
			break;
		case 4:
			quote += "'This learner bike is so cool and beautifully crafted.' - Elena Dalrymple, Mother & Baby Magazine";
			break;
	}
	
	quote += "</a>"
	
	return quote

}

function settime(sp,imgid){
	setTimeout(function(){
		jQuery('#' + imgid).fadeIn(500);
	},sp);	
}
//function to disable the Bikes and Helmets pagees....
//function applyGroupClass(groupName) {
//	jQuery('#nav').find('a').attr('title',groupName).addClass('current_page_item');
//}

