/* Zebra Functions */

;(function(h){var m=h.scrollTo=function(b,c,g){h(window).scrollTo(b,c,g)};m.defaults={axis:'y',duration:1};m.window=function(b){return h(window).scrollable()};h.fn.scrollable=function(){return this.map(function(){var b=this.parentWindow||this.defaultView,c=this.nodeName=='#document'?b.frameElement||b:this,g=c.contentDocument||(c.contentWindow||c).document,i=c.setInterval;return c.nodeName=='IFRAME'||i&&h.browser.safari?g.body:i?g.documentElement:this})};h.fn.scrollTo=function(r,j,a){if(typeof j=='object'){a=j;j=0}if(typeof a=='function')a={onAfter:a};a=h.extend({},m.defaults,a);j=j||a.speed||a.duration;a.queue=a.queue&&a.axis.length>1;if(a.queue)j/=2;a.offset=n(a.offset);a.over=n(a.over);return this.scrollable().each(function(){var k=this,o=h(k),d=r,l,e={},p=o.is('html,body');switch(typeof d){case'number':case'string':if(/^([+-]=)?\d+(px)?$/.test(d)){d=n(d);break}d=h(d,this);case'object':if(d.is||d.style)l=(d=h(d)).offset()}h.each(a.axis.split(''),function(b,c){var g=c=='x'?'Left':'Top',i=g.toLowerCase(),f='scroll'+g,s=k[f],t=c=='x'?'Width':'Height',v=t.toLowerCase();if(l){e[f]=l[i]+(p?0:s-o.offset()[i]);if(a.margin){e[f]-=parseInt(d.css('margin'+g))||0;e[f]-=parseInt(d.css('border'+g+'Width'))||0}e[f]+=a.offset[i]||0;if(a.over[i])e[f]+=d[v]()*a.over[i]}else e[f]=d[i];if(/^\d+$/.test(e[f]))e[f]=e[f]<=0?0:Math.min(e[f],u(t));if(!b&&a.queue){if(s!=e[f])q(a.onAfterFirst);delete e[f]}});q(a.onAfter);function q(b){o.animate(e,j,a.easing,b&&function(){b.call(this,r,a)})};function u(b){var c='scroll'+b,g=k.ownerDocument;return p?Math.max(g.documentElement[c],g.body[c]):k[c]}}).end()};function n(b){return typeof b=='object'?b:{top:b,left:b}}})(jQuery);

function replayform(id, type) {
	if (type == 'show') {
		$('.textarea_comment').each(function(){
			$(this).hide('slow');
		});
		$('.replay').each(function(){
			$(this).show();
		});
		$('#textarea_'+id).show('slow');
		$('#replay_'+id).hide('slow');
	} else {
		$('.textarea_comment').each(function(){
			$(this).hide('slow');
		});
		$('.replay').each(function(){
			$(this).show();
		});
		$('#textarea_main').show('slow');
	}
}

function sendcomment(parent_id, id, type) {
	var comment = $('#message_'+parent_id).val();
	var type_info = $('#type_info').val();
	$.ajax({
		type: 'POST',
		url: baseURL,
		data: 'controller=comment&action=post&ajax=true&id='+id+'&parent_id='+parent_id+'&topic='+comment+'&type_info='+type_info+'&type='+type,
		dataType: 'html',
		success: function(msg){
			if (msg == 1) {
				alert('Comment was submit with error!');
			} else {
				$('#comments-list').html(msg);
				forcomments();
				var name_scroll = $('#scrool_id').val();
				$.scrollTo($('a[name=name'+name_scroll+']'), 'slow');
			}
		}
		});
}

$.showFlashPlayer = function() {
	
	$('#result-loading').attr('style', '');
	$('#flashcontent').attr('style', 'position: fixed; left: 50%; top: 50%; width: 850px; height: 480px; margin: -240px 0 0 -425px; visibility: visible;');
	$('div.flash-here').attr('style', 'width: 100%; height: 100%; position: fixed; top: 0; left: 0; background: #fff;');
	$('div.flash-here').fadeTo('slow', 0.5);
	
}

$(document).ready(function() { 
    $('#link_bug_report').click(function() { 
        $.blockUI({ message: $('#bug_report') }); 
        $('.blockOverlay').attr('title','Click to unblock').click($.unblockUI); 
        //setTimeout($.unblockUI, 2000);
    });
    
    
    $('#send_bug_report').click(function() { 
    	
    	message_about_bug = $('#message_about_bug').val();
		$.ajax({
		type: 'POST',
		url: baseURL,
		data: 'controller=bug&action=add&ajax=true&varText='+message_about_bug,
		dataType: 'html',
		success: function(html){
			 $.unblockUI();
		}
		});
    });    
    
      
});

function setuplinks() {
	$('a.playfullvideo').click(function() {
		id = $(this).attr('id_set');
		
		type = 'flv';
		$.ajax({
		type: 'GET',
		url: baseURL,
		data: 'controller=video&action=flashcontent&ajax=true&id='+id,
		dataType: 'html',
		success: function(html){
			$('#flash-here').remove();
			$('body').append(html);
			
			var str_pl = $('#player_str').val();
			var so = new SWFObject('player.swf', 'player', '560', '336', '8');
			so.addVariable('width', '560');
			so.addVariable('height', '336');
			so.addParam('allowfullscreen', 'true');
			so.addParam('wmode', 'opaque');
			
			movieName = baseURL+'video/play/'+id+'/1.flv';
			timeoutMls = 10;
			setTimeout(function() {
				$('#set-movie *').hide();
				so.addVariable('autostart', 'true');
				so.addParam('FlashVars', str_pl);
				so.write("flashcontent");
				$('#result-loading, #result-loading-full').attr('style', '');
				$('#flash-here').attr('style', 'width: 100%; height: 100%; visibility: visible; background: url(templates/images/bg.png); position: fixed; left: 0; top: 0;');
				$('#flash-here-close').attr('style', 'width: 100%; height: 100%; visibility: visible; background: url(templates/images/bg.png); position: absolute; left: 0; top: 0;');
				$('#flashcontent').attr('style', 'width: 560px; height: 336px; visibility: visible; position: absolute; left: 50%; top: 50%; margin: -168px 0 0 -280px;');
			}, timeoutMls);
			
			$('#flash-here-close').click(function() {
				$('#set-movie *').show();
				$('#flash-here').remove();
			});
		}
		});
			
		return false;
		
	});	
}

$.getVideo = function(params) {
	
	id = params.id;
	type = params.type;
	flvdownload = params.flvdownload;
	start = params.start;
	duration = params.duration;
	interval = params.interval;
	
	if (start == false && duration == false ) {
		$('#result-loading-full').attr('style', 'visibility: visible;');
	}
	else {
		$('#result-loading').attr('style', 'visibility: visible;');
	}
	
	if (flvdownload == true) {
		var type = 'flv';
		var quality = 1;
	}
	else {
		quality = 0;
	}
	
	$.ajax({
		type: 'GET',
		url: baseURL,
		data: 'controller=video&action=generate&id='+id+'&type='+type+'&start='+start+'&duration='+duration+'&quality='+quality+'&ajax=true',
		dataType: 'html',
		success: function(html){			
			
			file = $('#filename', html).attr('value');
			id = $('#set-id', html).attr('value');
			
			if (type == 'flv' && flvdownload != true) {
				
				$('#flash-here').remove();
				$('body').append(html);
				
				var so = new SWFObject('mediaplayer.swf', 'player', '560', '336', '8', '#FFFFFF');
				so.addVariable('width', '560');
				so.addVariable('height', '336');
				so.addParam('allowfullscreen', 'true');
				movieName = baseURL+'video/play/'+id+'/'+file;
				timeoutMls = 1000;
				//timeoutMls = Math.round(duration/interval);
				//timeoutMls = timeoutMls * 750;
				//if(timeoutMls < 1000 || isNaN(timeoutMls) == true) { timeoutMls = 1000; }
				setTimeout(function() {
					$('#set-movie *').hide();
					so.addVariable('autostart', 'true');
					so.addVariable('file', movieName);
					so.write("flashcontent");
					$('#result-loading, #result-loading-full').attr('style', '');
					$('#flash-here').attr('style', 'width: 100%; height: 100%; visibility: visible; background: url(templates/images/bg.png); position: fixed; left: 0; top: 0;');
					$('#flash-here-close').attr('style', 'width: 100%; height: 100%; visibility: visible; background: url(templates/images/bg.png); position: absolute; left: 0; top: 0;');
					$('#flashcontent').attr('style', 'width: 560px; height: 336px; visibility: visible; position: absolute; left: 50%; top: 50%; margin: -168px 0 0 -280px;');
				}, timeoutMls);
				
				$('#flash-here-close').click(function() {
					$('#set-movie *').show();
					$('#flash-here').remove();
				});
				
			}
			else if (type == 'mpg' || type == 'wmv') {
				
				$('#result-loading, #result-loading-full').attr('style', '');
				if ($.browser.msie || $.browser.mozilla) {
					if (start == false && duration == false && $('div.set-actions')) {
						$('div.set-actions').append('<div class="download-options-movie"><a href="'+baseURL+'video/download/'+id+'/'+file+'" target="_blank" id="msie-download">Click here to download file</a></div>');
					}
					else {
						$('div.set-scenes-actions').append('<div class="download-options"><a href="'+baseURL+'video/download/'+id+'/'+file+'" target="_blank" id="msie-download">Click here to download file</a></div>');
					}
					$('#msie-download').unbind('click');
					$('#msie-download').bind('click', function() {
						$(this).parent().remove();
					});
				}
				else {
					$('body').append('<iframe src="'+baseURL+'video/download/'+id+'/'+file+'" style="position: absolute; left: 0; top: 0; width: 0; height: 0;"></iframe>');
				}
				
			}
			else if (type == 'flv' && flvdownload == true) {
				
				setTimeout(function() {
					$('#result-loading, #result-loading-full').attr('style', '');
					$('body').append('<iframe src="'+baseURL+'video/download/'+id+'/'+file+'" style="position: absolute; left: 0; top: 0; width: 0; height: 0;"></iframe>');
				}, 500);
				
			}
			else {
				
				alert('Unknown action!');
				
			}
			
			$('#download-options, #download-options-movie').hide();
			
		}
	});
	
}

$.addToCart = function(params) {
	
	id = params.id;
	type = params.type;
	start = params.start;
	duration = params.duration;
	files = params.files;
	
	$('#set-movie *').hide();
	
	if (type == 'movie') {
		
		if (start != false) {
			cartTitle = 'Add selected scenes to favorites';
		}
		else {
			cartTitle = 'Add movie to favorites';
		}
		
		$('body').append('<div id="add-to-cart"><h2>'+cartTitle+'</h2><p>Set movie name:<br /><input type="text" id="add-cart-title" /></p><p>Set movie description:<br /><textarea id="add-cart-description"></textarea></p><p><input type="button" id="add-cart-submit" value="Add to cart" /> <input type="button" id="add-cart-close" value="Close" /></div>');
		
		$('#add-cart-submit').click(function() {
			
			title = $('#add-cart-title').attr('value');
			description = $('#add-cart-description').attr('value');
			
			if (title != null) {
				$.get(
					baseURL,
					{
						controller: 'video',
						action: 'addtocart',
						id: id,
						ajax: 'true',
						title: title,
						description: description,
						start: start,
						duration: duration
					},
					function() {
						$('#set-movie *').show();
						$('#add-to-cart').remove();
					}
					
				);
			}
			else {
				alert('Title have null value, please check it.');
			}
		
		});
	}	
	else if (type == 'photo') {
		
		if (start != false) {
			cartTitle = 'Add selected photos to favorites';
		}
		else {
			cartTitle = 'Add photoset to favorites';
		}
		
		$('body').append('<div id="add-to-cart"><h2>'+cartTitle+'</h2><p>Set photoset name:<br /><input type="text" id="add-cart-title" /></p><p>Set photoset description:<br /><textarea id="add-cart-description"></textarea></p><p><input type="button" id="add-cart-submit" value="Add to cart" /> <input type="button" id="add-cart-close" value="Close" /></div>');
		
		$('#add-cart-submit').click(function() {
			
			title = $('#add-cart-title').attr('value');
			description = $('#add-cart-description').attr('value');
			
			if (title != null) {
				$.get(
					baseURL,
					{
						controller: 'photo',
						action: 'addtocart',
						id: id,
						ajax: 'true',
						title: title,
						description: description,
						files: files
					},
					function() {
						$('#add-to-cart').remove();
					}
					
				);
			}
			else {
				alert('Title have null value, please check it.');
			}
		
		});
		
	}
	else {
		alert('Unknown action!');
	}
	
	$('#add-cart-close').click(function() {
		
		$('#set-movie *').show();
		$('#add-to-cart').remove();
	
	});
	
}

$.viewPhoto = function(params) {
	id = params.id;
	eq = params.eq;
	name = params.name;
	commentImage = params.commentImage;
	imageURL = params.imageURL;
	width = $('#view-photoset').width();
	height = $('#view-photoset').height();
	
	$('#loading-image').attr('style', 'visibility: visible;');
	$('#view-photo').empty();
	$('#view-photo').removeAttr('style');
	
	if (commentImage == true) {
		$('#view-photo').append('<img src="'+imageURL+'" alt="'+eq+'" style="visibility: hidden;" />');
	}
	else {
		$('#view-photo').append('<img src="'+baseURL+'?controller=photo&action=viewimage&id='+id+'&filename='+name+'&width='+width+'&height='+height+'&ajax=true" alt="'+eq+'" style="visibility: hidden;" />');
	}
	
	eqLast = $('#view-list img').index($('#view-list img:last')[0]);
	if (eqLast == 0) {
		$('#view-prev').attr('style', 'visibility: hidden;');
		$('#view-next').attr('style', 'visibility: hidden;');
		$('#view-list-wrap').hide();
	}
	else if (eq == 0) {
		$('#view-prev').attr('style', 'visibility: hidden;');
		$('#view-next').attr('style', 'visibility: visible;');
	}
	else if (eq == eqLast) {
		$('#view-next').attr('style', 'visibility: hidden;');
		$('#view-prev').attr('style', 'visibility: visible;');
	}
	else {
		$('#view-next, #view-prev').attr('style', 'visibility: visible;');
	}
	
	$('#view-photo img').load(function() {
		
		width = $('#view-photo img').width();
		height = $('#view-photo img').height();
		minusWidth = Math.round(width/2);
		minusHeight = Math.round(height/2);
		
		$('#loading-image').removeAttr('style');
		$('#view-photo').attr('style', 'left: 50%; top: 50%; margin: -'+minusHeight+'px 0 0 -'+minusWidth+'px;');
		$('#view-photo').animate({ width: width+'px', height: height+'px' }, 100);
		$('#view-photo img').attr('style', 'width: '+width+'px; height: '+height+'px; visibility: visible;');
		
	});

};

$.checkLength = function(params) {
	maxLength = params.max;
	currentLength = params.current;
	object = params.object;
	text = $(object).next().text();
	
	if (currentLength > maxLength) {
		alert(text);
	}
	else {
		return false;
	}

}

$.postComment = function(params) {
	
	type = params.type;
	content_id = params.content_id;
	topic = params.topic;
	var type_info = $('#type_info').val();
	url = $('#newcomment').attr('action');
	
	$.post(
		url,
		{
			ajax: 'true',
			type: type,
			id: content_id,
			topic: topic,
			type_info: type_info
		},
		function(data) {
			if (data == 1) {
				alert('Comment was submit with error!');
			}
			else {
				$('#comments-list').html(data);
				forcomments();
				var name_scroll = $('#scrool_id').val();
				$.scrollTo($('a[name=name'+name_scroll+']'), 'slow');
			}
		}
	);
	
	$('#comment_list a[href$=".jpg"]').click(function() {
		
		thumb = $(this).children();
		imageURL = $(this).attr('href');
		
		$('#view-list').empty();
		$(thumb).clone().appendTo('#view-list');
		$('#view-list img').wrap('<li></li>');
		$('#view-list img').attr('class', '');
		$('#view-list img:eq(0)').attr('class', 'selected');
		$('#main').attr('style', 'height: 100%; overflow: hidden;');
		$('#view-photoset').show();
		$('#view-next, #view-prev').attr('style', 'visibility: hidden;');
		
		id = $('#photo-id').attr('value');
		eq = $('#view-list img').index($('#view-list img:eq(0)')[0]);
		name = $('#view-list img.selected').attr('alt');
		$.viewPhoto({ id: id, eq: eq, name: name, commentImage: true, imageURL: imageURL });
		
		return false;
	
	});
	
	$('span.comment-rate-plus, span.comment-rate-minus').click(function() {
		
		itemId = $(this).parent().attr('comment');
		itemClass = $(this).attr('class');
		
		if (itemClass == 'comment-rate-plus') {
			rating = '+1';
		}
		else if (itemClass == 'comment-rate-minus') {
			rating = '-1';
		}
		else {
			return false;
		}
		
		$.get(
			baseURL,
			{
				controller: 'comment',
				action: 'vote',
				id: itemId,
				rating: rating,
				ajax: 'true'
			},
			function(data) {
				$('#rating_'+itemId).html(data);
			}
		);
		
	});

}


/***************************************/
// jQuery Tabber
// By Jordan Boesch
// www.boedesign.com
// Dec 25, 2007 (Merry Christmas!)
/***************************************/

function ajax(url, method, params, before, success, error) {
	options = {
		url:url,
		method:method
	}
	if (params != undefined && params != '') options['data'] = params
	if (before != undefined && before != '') options['beforeSend'] = before;
	if (success != undefined && success != '') options['success'] = success;
	if (error != undefined && error != '') options['error'] = error;
	$.ajax(options)
}

(function($){

		$.jtabber = function(params){
				
				// parameters
				var navDiv = params.mainLinkTag;
				var selectedClass = params.activeLinkClass;
				var hiddenContentDiv = params.hiddenContentClass;
				var showDefaultTab = params.showDefaultTab;
				var showErrors = params.showErrors;
				var effect = params.effect;
				var effectSpeed = params.effectSpeed;
				
				// If error checking is enabled
				if(showErrors){
					if(!$(navDiv).attr('href')){
						alert("ERROR: The elements in your mainLinkTag paramater need a 'title' attribute.\n ("+navDiv+")");	
						return false;
					}
					else if(!$("."+hiddenContentDiv).attr('id')){
						alert("ERROR: The elements in your hiddenContentClass paramater need to have an id.\n (."+hiddenContentDiv+")");	
						return false;
					}
				}
				
				// If we want to show the first block of content when the page loads
				if(!isNaN(showDefaultTab)){
					showDefaultTab--;
					$("."+hiddenContentDiv+":eq("+showDefaultTab+")").css('display','block');
					$(navDiv+":eq("+showDefaultTab+")").addClass(selectedClass);	
				}
				
				// each anchor
				$(navDiv).each(function(){
										
					$(this).click(function(){
						// once clicked, remove all classes
						$(navDiv).each(function(){
							$(this).removeClass();
						})
						// hide all content
						$("."+hiddenContentDiv).css('display','none');
						
						// now lets show the desired information
						$(this).addClass(selectedClass);
						var contentDivId = $(this).attr('href');
						
						if(effect != null){
							
							switch(effect){
								
								case 'slide':
								$(contentDivId).slideDown(effectSpeed);
								break;
								case 'fade':
								$(contentDivId).fadeIn(effectSpeed);
								break;
								
							}
								
						}
						else {
							$(contentDivId).css('display','block');
						}
						return false;
					})
				})
			
			}
	
})(jQuery);

/*
	Copyright (c) 2008 Aaron E. [jquery at happinessinmycheeks dot com] 
	v.1.1
*/
jQuery.extend(jQuery.expr[':'], {
	between:	"i >= (parseInt(m[3].split(',')[0]) <= parseInt(m[3].split(',')[1]) ? parseInt(m[3].split(',')[0]) : parseInt(m[3].split(',')[1])) && i <= (parseInt(m[3].split(',')[1]) >= parseInt(m[3].split(',')[0]) ? parseInt(m[3].split(',')[1]) : parseInt(m[3].split(',')[0]))",
	except:		"i < (parseInt(m[3].split(',')[0]) <= parseInt(m[3].split(',')[1]) ? parseInt(m[3].split(',')[0]) : parseInt(m[3].split(',')[1])) || i > (parseInt(m[3].split(',')[1]) > parseInt(m[3].split(',')[0]) ? parseInt(m[3].split(',')[1]) : parseInt(m[3].split(',')[0]))"
});


function Rating(div_id){
	this.div = document.getElementById(div_id);
	this.id = this.div.getAttribute("id");
	this.rating = this.div.getAttribute("rating");
	this.enabled = this.div.getAttribute("enabled") == "1" ? true : false ;
	this.imgPath = this.div.getAttribute("imgPath");
	this.file = this.div.getAttribute("file");
	this.stars = new Array();
	this.starTypes = new Array();

	this.createStars();
};


Rating.prototype.recalculateStars = function (rating){
	if (rating > 5) {
		rating = 5;
	}
	var roundRating = Math.round(rating * 2) / 2;
	var floorRating = Math.floor(roundRating);

	for (var i=1; i <= roundRating; i++){
		this.starTypes[i] = this.imgPath + 'rating_on.gif';
	};

	if (floorRating != roundRating) {
		this.starTypes[floorRating + 1] = this.imgPath + 'rating_half.gif';
		floorRating++;
	};	
	
	for (var i = floorRating + 1; i <= 5; i++){
		this.starTypes[i] = this.imgPath + 'rating_off.gif';
	};
}

Rating.prototype.createStars = function (){
	this.div.innerHTML = "";
	this.recalculateStars(this.rating);
	
	var thisCopy = this;	
	for (var i = 1; i <= 5; i++){
		this.stars[i] = document.createElement("IMG");
		this.stars[i].ratingNum = i;
		this.stars[i].src = this.starTypes[i];
		this.stars[i].width = 14;
		this.stars[i].height = 14;
		this.stars[i].border = 0;
		this.stars[i].alt = i;
		this.stars[i].onmouseover = function() { if (thisCopy.enabled) thisCopy.mouseOver(this.ratingNum) };
		this.stars[i].onmouseout = function() { if (thisCopy.enabled) thisCopy.mouseOut(this.ratingNum) };
		this.stars[i].onclick = function() { if (thisCopy.enabled) thisCopy.mouseClick(this.ratingNum) };
		this.div.appendChild(this.stars[i]);
	};	
};

Rating.prototype.mouseOver = function (num){
	for (var i=1; i <= num; i++){
		this.stars[i].src = this.imgPath + 'rating_over.gif';
	};
};

Rating.prototype.mouseOut = function (num){
	for (var i=1; i <= 5; i++){
		this.stars[i].src = this.starTypes[i];
	};
};

Rating.prototype.mouseClick = function (num){
	if (this.enabled) {
		$(this.div).fadeOut(300);
		var cur = this;
		$.get(
			this.file,
			{
				rating : num
			},
			function(data) {
				var uRating = $('div.user_rating', data).text();
				var cRating = $('div.rating', data).text();
				
				var siblingId = $('#'+cur.id).siblings('span').attr('id');
				if (siblingId == '') {
					var siblingId = $('#'+cur.id).parent('li').prev('li').children('span').not('.width-text').attr('id');
				}
				$('#'+siblingId).empty();
				$('#'+siblingId).attr('rating', cRating);
				var zzz = new Rating(siblingId);
				
				newRating = uRating.replace(/[^0-9\.\,]/g,'');
				if (newRating + "" != "") {
					cur.recalculateStars(parseInt(newRating));
					//alert($(this).siblings('span').attr('id'));
				}
				for (var i=1; i <= 5; i++){
					cur.stars[i].src = cur.starTypes[i];
				};
				curenabled = false;
				$(cur.div).fadeIn(300);
				if (cur.notifier) cur.notifier.hide();
			}
		);
		
/* 		var newRating = $.ajax({
		type: "GET",
		url: this.file,
		data: {
			rating : num
		},
		async: false
		}).responseText;
		 */
	};
};

/*
 * jQuery Form Plugin
 * @requires jQuery v1.1 or later
 *
 * Examples at: http://malsup.com/jquery/form/
 * Dual licensed under the MIT and GPL licenses:
 *   http://www.opensource.org/licenses/mit-license.php
 *   http://www.gnu.org/licenses/gpl.html
 *
 * Revision: $Id$
 */
(function($) {

$.fn.ajaxSubmit = function(options) {
	if (typeof options == 'function')
		options = { success: options };

	options = $.extend({
		url:  this.attr('action') || window.location,
		type: this.attr('method') || 'GET'
	}, options || {});
	var veto = {};
	$.event.trigger('form.pre.serialize', [this, options, veto]);
	if (veto.veto) return this;

	var a = this.formToArray(options.semantic);
	if (options.data) {
		for (var n in options.data)
			a.push( { name: n, value: options.data[n] } );
	}

	if (options.beforeSubmit && options.beforeSubmit(a, this, options) === false) return this;

	$.event.trigger('form.submit.validate', [a, this, options, veto]);
	if (veto.veto) return this;

	var q = $.param(a);

	if (options.type.toUpperCase() == 'GET') {
		options.url += (options.url.indexOf('?') >= 0 ? '&' : '?') + q;
		options.data = null;
	}
	else
		options.data = q;
	var $form = this, callbacks = [];
	if (options.resetForm) callbacks.push(function() { $form.resetForm(); });
	if (options.clearForm) callbacks.push(function() { $form.clearForm(); });

	if (!options.dataType && options.target) {
		var oldSuccess = options.success || function(){};
		callbacks.push(function(data) {
			if (this.evalScripts) {
				$(options.target).attr("innerHTML", data).evalScripts().each(oldSuccess, arguments);
			} else {
				$(options.target).html(data).each(oldSuccess, arguments);
			}
		});
	} else if (options.success)
		callbacks.push(options.success);
	options.success = function(data, status) {
		for (var i=0, max=callbacks.length; i < max; i++)
			callbacks[i](data, status, $form);
	};

	var files = $('input:file', this).fieldValue();
	var found = false;
	for (var j=0; j < files.length; j++)
		if (files[j])
			found = true;

	if (options.iframe || found)
		fileUpload();
	else
		$.ajax(options);
	$.event.trigger('form.submit.notify', [this, options]);
	return this;


	function fileUpload() {
		var form = $form[0];
		var opts = $.extend({}, $.ajaxSettings, options);

		var id = 'jqFormIO' + $.fn.ajaxSubmit.counter++;
		var $io = $('<iframe id="' + id + '" name="' + id + '" />');
		var io = $io[0];
		var op8 = $.browser.opera && window.opera.version() < 9;
		if ($.browser.msie || op8) io.src = 'javascript:false;document.write("");';
		$io.css({ position: 'absolute', top: '-1000px', left: '-1000px' });

		var xhr = {
			responseText: null,
			responseXML: null,
			status: 0,
			statusText: 'n/a',
			getAllResponseHeaders: function() {},
			getResponseHeader: function() {},
			setRequestHeader: function() {}
		};

		var g = opts.global;
		if (g && ! $.active++) $.event.trigger("ajaxStart");
		if (g) $.event.trigger("ajaxSend", [xhr, opts]);

		var cbInvoked = 0;
		var timedOut = 0;

		setTimeout(function() {
			$io.appendTo('body');
			io.attachEvent ? io.attachEvent('onload', cb) : io.addEventListener('load', cb, false);

			var encAttr = form.encoding ? 'encoding' : 'enctype';
			var t = $form.attr('target');
			$form.attr({
				target:   id,
				method:  'POST',
				action:   opts.url
			});
			form[encAttr] = 'multipart/form-data';

			if (opts.timeout)
				setTimeout(function() { timedOut = true; cb(); }, opts.timeout);

			form.submit();
			$form.attr('target', t);
		}, 10);

		function cb() {
			if (cbInvoked++) return;

			io.detachEvent ? io.detachEvent('onload', cb) : io.removeEventListener('load', cb, false);

			var ok = true;
			try {
				if (timedOut) throw 'timeout';
				var data, doc;
				doc = io.contentWindow ? io.contentWindow.document : (io.contentDocument ? io.contentDocument : io.document);
				xhr.responseText = doc.body ? doc.body.innerHTML : null;
				xhr.responseXML = doc.XMLDocument ? doc.XMLDocument : doc;
				if (opts.dataType == 'json' || opts.dataType == 'script') {
					var ta = doc.getElementsByTagName('textarea')[0];
					data = ta ? ta.value : xhr.responseText;
					if (opts.dataType == 'json')
						eval("data = " + data);
					else
						$.globalEval(data);
				}
				else if (opts.dataType == 'xml') {
					data = xhr.responseXML;
					if (!data && xhr.responseText != null)
						data = toXml(xhr.responseText);
				}
				else {
					data = xhr.responseText;
				}
			}
			catch(e){
				ok = false;
				$.handleError(opts, xhr, 'error', e);
			}

			if (ok) {
				opts.success(data, 'success');
				if (g) $.event.trigger("ajaxSuccess", [xhr, opts]);
			}
			if (g) $.event.trigger("ajaxComplete", [xhr, opts]);
			if (g && ! --$.active) $.event.trigger("ajaxStop");
			if (opts.complete) opts.complete(xhr, ok ? 'success' : 'error');

			setTimeout(function() {
				$io.remove();
				xhr.responseXML = null;
			}, 100);
		};

		function toXml(s, doc) {
			if (window.ActiveXObject) {
				doc = new ActiveXObject('Microsoft.XMLDOM');
				doc.async = 'false';
				doc.loadXML(s);
			}
			else
				doc = (new DOMParser()).parseFromString(s, 'text/xml');
			return (doc && doc.documentElement && doc.documentElement.tagName != 'parsererror') ? doc : null;
		};
	};
};
$.fn.ajaxSubmit.counter = 0;

$.fn.ajaxForm = function(options) {
	return this.ajaxFormUnbind().submit(submitHandler).each(function() {
		this.formPluginId = $.fn.ajaxForm.counter++;
		$.fn.ajaxForm.optionHash[this.formPluginId] = options;
		$(":submit,input:image", this).click(clickHandler);
	});
};

$.fn.ajaxForm.counter = 1;
$.fn.ajaxForm.optionHash = {};

function clickHandler(e) {
	
	var $form = this;
	$form.clk = true;
	
	
	
	
	if (this.type == 'image') {
		if (e.offsetX != undefined) {
			$form.clk_x = e.offsetX;
			$form.clk_y = e.offsetY;
		} else if (typeof $.fn.offset == 'function') { // try to use dimensions plugin
			var offset = $(this).offset();
			$form.clk_x = e.pageX - offset.left;
			$form.clk_y = e.pageY - offset.top;
		} else {
			$form.clk_x = e.pageX - this.offsetLeft;
			$form.clk_y = e.pageY - this.offsetTop;
		}
	}
	setTimeout(function() { $form.clk = $form.clk_x = $form.clk_y = null; }, 10);
};

function submitHandler() {
	var id = this.formPluginId;
	var options = $.fn.ajaxForm.optionHash[id];
	$(this).ajaxSubmit(options);
	return false;
};

/**
 * ajaxFormUnbind unbinds the event handlers that were bound by ajaxForm
 *
 * @name   ajaxFormUnbind
 * @return jQuery
 * @cat	Plugins/Form
 * @type   jQuery
 */
$.fn.ajaxFormUnbind = function() {
	this.unbind('submit', submitHandler);
	return this.each(function() {
		$(":submit,input:image", this).unbind('click', clickHandler);
	});

};

$.fn.formToArray = function(semantic) {
	var a = [];
	if (this.length == 0) return a;

	var form = this[0];
	var els = semantic ? form.getElementsByTagName('*') : form.elements;
	if (!els) return a;
	for(var i=0, max=els.length; i < max; i++) {
		var el = els[i];
		var n = el.name;
		if (!n) continue;

		if (semantic && form.clk && el.type == "image") {
			if(!el.disabled && form.clk == el)
				a.push({name: n+'.x', value: form.clk_x}, {name: n+'.y', value: form.clk_y});
			continue;
		}

		var v = $.fieldValue(el, true);
		if (v && v.constructor == Array) {
			for(var j=0, jmax=v.length; j < jmax; j++)
				a.push({name: n, value: v[j]});
		}
		else if (v !== null && typeof v != 'undefined')
			a.push({name: n, value: v});
	}

	if (!semantic && form.clk) {
		var inputs = form.getElementsByTagName("input");
		for(var i=0, max=inputs.length; i < max; i++) {
			var input = inputs[i];
			var n = input.name;
			if(n && !input.disabled && input.type == "image" && form.clk == input)
				a.push({name: n+'.x', value: form.clk_x}, {name: n+'.y', value: form.clk_y});
		}
	}
	return a;
};


$.fn.formSerialize = function(semantic) {
	return $.param(this.formToArray(semantic));
};


$.fn.fieldSerialize = function(successful) {
	var a = [];
	this.each(function() {
		var n = this.name;
		if (!n) return;
		var v = $.fieldValue(this, successful);
		if (v && v.constructor == Array) {
			for (var i=0,max=v.length; i < max; i++)
				a.push({name: n, value: v[i]});
		}
		else if (v !== null && typeof v != 'undefined')
			a.push({name: this.name, value: v});
	});
	return $.param(a);
};


$.fn.fieldValue = function(successful) {
	for (var val=[], i=0, max=this.length; i < max; i++) {
		var el = this[i];
		var v = $.fieldValue(el, successful);
		if (v === null || typeof v == 'undefined' || (v.constructor == Array && !v.length))
			continue;
		v.constructor == Array ? $.merge(val, v) : val.push(v);
	}
	return val;
};

$.fieldValue = function(el, successful) {
	var n = el.name, t = el.type, tag = el.tagName.toLowerCase();
	if (typeof successful == 'undefined') successful = true;

	if (successful && (!n || el.disabled || t == 'reset' || t == 'button' ||
		(t == 'checkbox' || t == 'radio') && !el.checked ||
		(t == 'submit' || t == 'image') && el.form && el.form.clk != el ||
		tag == 'select' && el.selectedIndex == -1))
			return null;

	if (tag == 'select') {
		var index = el.selectedIndex;
		if (index < 0) return null;
		var a = [], ops = el.options;
		var one = (t == 'select-one');
		var max = (one ? index+1 : ops.length);
		for(var i=(one ? index : 0); i < max; i++) {
			var op = ops[i];
			if (op.selected) {
				var v = $.browser.msie && !(op.attributes['value'].specified) ? op.text : op.value;
				if (one) return v;
				a.push(v);
			}
		}
		return a;
	}
	return el.value;
};


$.fn.clearForm = function() {
	return this.each(function() {
		$('input,select,textarea', this).clearFields();
	});
};

$.fn.clearFields = $.fn.clearInputs = function() {
	return this.each(function() {
		var t = this.type, tag = this.tagName.toLowerCase();
		if (t == 'text' || t == 'password' || tag == 'textarea')
			this.value = '';
		else if (t == 'checkbox' || t == 'radio')
			this.checked = false;
		else if (tag == 'select')
			this.selectedIndex = -1;
	});
};


$.fn.resetForm = function() {
	return this.each(function() {
		if (typeof this.reset == 'function' || (typeof this.reset == 'object' && !this.reset.nodeType))
			this.reset();
	});
};

})(jQuery);

(function($) {
$.fn.jCarouselLite = function(o) {
	o = $.extend({
		btnPrev: null,
		btnNext: null,
		btnGo: null,
		mouseWheel: false,
		auto: null,

		speed: 200,
		easing: null,

		vertical: false,
		circular: true,
		visible: 3,
		start: 0,
		scroll: 1,

		beforeStart: null,
		afterEnd: null
	}, o || {});

	return this.each(function() {						   // Returns the element collection. Chainable.

		var running = false, animCss=o.vertical?"top":"left", sizeCss=o.vertical?"height":"width";
		var div = $(this), ul = $("ul", div), tLi = $("li", ul), tl = tLi.size(), v = o.visible;

		if(o.circular) {
			ul.prepend(tLi.slice(tl-v-1+1).clone())
			  .append(tLi.slice(0,v).clone());
			o.start += v;
		}

		var li = $("li", ul), itemLength = li.size(), curr = o.start;
		div.css("visibility", "visible");

		li.css({overflow: "hidden", float: o.vertical ? "none" : "left"});
		ul.css({margin: "0", padding: "0", position: "relative", "list-style-type": "none", "z-index": "1"});
		div.css({overflow: "hidden", position: "relative", "z-index": "2", left: "0px"});

		var liSize = o.vertical ? height(li) : width(li);   // Full li size(incl margin)-Used for animation
		var ulSize = liSize * itemLength;				   // size of full ul(total length, not just for the visible items)
		var divSize = liSize * v;						   // size of entire div(total length for just the visible items)

		li.css({width: li.width(), height: li.height()});
		ul.css(sizeCss, ulSize+"px").css(animCss, -(curr*liSize));

		div.css(sizeCss, divSize+"px");					 // Width of the DIV. length of visible images

		if(o.btnPrev)
			$(o.btnPrev).click(function() {
				return go(curr-o.scroll);
			});

		if(o.btnNext)
			$(o.btnNext).click(function() {
				return go(curr+o.scroll);
			});

		if(o.btnGo)
			$.each(o.btnGo, function(i, val) {
				$(val).click(function() {
					return go(o.circular ? o.visible+i : i);
				});
			});

		if(o.mouseWheel && div.mousewheel)
			div.mousewheel(function(e, d) {
				return d>0 ? go(curr-o.scroll) : go(curr+o.scroll);
			});

		if(o.auto)
			setInterval(function() {
				go(curr+o.scroll);
			}, o.auto+o.speed);

		function vis() {
			return li.slice(curr).slice(0,v);
		};

		function go(to) {
			if(!running) {

				if(o.beforeStart)
					o.beforeStart.call(this, vis());

				if(o.circular) {			// If circular we are in first or last, then goto the other end
					if(to<=o.start-v-1) {		   // If first, then goto last
						ul.css(animCss, -((itemLength-(v*2))*liSize)+"px");
						// If "scroll" > 1, then the "to" might not be equal to the condition; it can be lesser depending on the number of elements.
						curr = to==o.start-v-1 ? itemLength-(v*2)-1 : itemLength-(v*2)-o.scroll;
					} else if(to>=itemLength-v+1) { // If last, then goto first
						ul.css(animCss, -( (v) * liSize ) + "px" );
						// If "scroll" > 1, then the "to" might not be equal to the condition; it can be greater depending on the number of elements.
						curr = to==itemLength-v+1 ? v+1 : v+o.scroll;
					} else curr = to;
				} else {					// If non-circular and to points to first or last, we just return.
					if(to<0 || to>itemLength-v) return;
					else curr = to;
				}						   // If neither overrides it, the curr will still be "to" and we can proceed.

				running = true;

				ul.animate(
					animCss == "left" ? { left: -(curr*liSize) } : { top: -(curr*liSize) } , o.speed, o.easing,
					function() {
						if(o.afterEnd)
							o.afterEnd.call(this, vis());
						running = false;
					}
				);
				// Disable buttons when the carousel reaches the last/first, and enable when not
				if(!o.circular) {
					$(o.btnPrev + "," + o.btnNext).removeClass("disabled");
					$( (curr-o.scroll<0 && o.btnPrev)
						||
					   (curr+o.scroll > itemLength-v && o.btnNext)
						||
					   []
					 ).addClass("disabled");
				}

			}
			return false;
		};
	});
};

function css(el, prop) {
	return parseInt($.css(el[0], prop)) || 0;
};
function width(el) {
	return  el[0].offsetWidth + css(el, 'marginLeft') + css(el, 'marginRight');
};
function height(el) {
	return el[0].offsetHeight + css(el, 'marginTop') + css(el, 'marginBottom');
};

})(jQuery);
