jQuery.noConflict();

function moveFeedback() {
	var y = (document.documentElement.clientHeight || document.body.clientHeight) / 2 - (jQuery('#feedback-icon').outerHeight() / 2)
		+ (document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop);
		
	if (jQuery.browser.msie) {
		jQuery('#feedback-icon').stop().animate({'top': y.toString()});
	}
	else {
		jQuery('#feedback-icon').stop().css('opacity', 1).animate({'top': y.toString()});
	}
}

jQuery(document).ready(function () {
	try {
		jQuery("img.pngfix").pngfix();
	}
	catch (e) {};
	
	jQuery(window).scroll(function () {
		moveFeedback();
	});
	
	jQuery(window).resize(function () {
		moveFeedback();
	});

	var _fby = (document.documentElement.clientHeight || document.body.clientHeight) / 2 - (jQuery('#feedback-icon').outerHeight() / 2)
		+ (document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop);
	if (jQuery.browser.msie) {
		jQuery('#feedback-icon').stop().css({'top': _fby.toString()}).show();
	}
	else {
		jQuery('#feedback-icon').stop().css('top', _fby.toString()+'px').show();
	}

	var isz = jQuery('#promo-rotator ul li:first').outerWidth();
	var sz = isz * jQuery('#promo-rotator ul li').size();
	jQuery('#promo-rotator ul').css('width', sz.toString()+'px');

	jQuery('div.rating-selector a').hover(function (ev) {
		jQuery(this).addClass('hover');
	
		var list = jQuery('div.rating-selector a');
		var idx = list.index(jQuery(this));
		var x = ((idx+1) * 18) - 90;
		jQuery(this).parent().css('background-position', x.toString()+'px 0');
		
		list.each(function (i, e) {
			if (i < idx) jQuery(this).addClass('hover');
		});
	}, function (ev) {
		var none = true;
		var frm = jQuery(this).parents('form')[0];
		if (frm)
		{
			var input = jQuery('input.rating-value', frm);
			if (input)
			{
				var x = (parseInt(input.val()) * 18) - 90;
				jQuery(this).parent().css('background-position', x.toString()+'px 0');
				none = false;
			}
		}
		
		if (none)
		{
			jQuery(this).parent().css('background-position', '100% 0');
		}
	});

	jQuery('div.rating-selector a').click(function (ev) {
		ev.preventDefault();
		
		var list = jQuery('div.rating-selector a');
		var idx = list.index(jQuery(this)) + 1;

		var frm = jQuery(this).parents('form')[0];
		if (frm) {
			jQuery('input.rating-value', frm).val(idx);
		}
	});
	
	jQuery('#promo-rotator a.rotate-left').click(function (ev) {
		ev.preventDefault();

		var left = jQuery('#promo-rotator-inner').scrollLeft();
		left = left - isz;
		if (left < 0)
		{
			left = jQuery('#promo-rotator ul').outerWidth() - isz;
		}
		left = Math.max(left, 0);
		jQuery('#promo-rotator-inner').stop().animate({scrollLeft:left.toString() + 'px'}, 500);
	});

	jQuery('#promo-rotator a.rotate-right').click(function (ev) {
		ev.preventDefault();

		var left = jQuery('#promo-rotator-inner').scrollLeft();
		left = left + isz;
		if (left >= jQuery('#promo-rotator ul').outerWidth())
		{
			left = 0;
		}	
		jQuery('#promo-rotator-inner').stop().animate({scrollLeft:left.toString() + 'px'}, 500);
	});
	
	jQuery('#promo-rotator').everyTime(6000, 'rot', function(i) {
		jQuery('#promo-rotator a.rotate-right').trigger('click');
	});

	jQuery("#ContactForm").validationEngine();
	jQuery("#FeedbackForm").validationEngine();
});


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);
		}
});

