/**
 * jQuery bxSlider v3.0 http://bxslider.com
 * 
 * Copyright 2010, Steven Wanderski http://stevenwanderski.com
 * 
 * Free to use and abuse under the MIT license.
 * http://www.opensource.org/licenses/mit-license.php
 * 
 */
(function($) {
	$.fn.bxSlider = function(options) {
		var defaults = {
			mode : 'horizontal',
			infiniteLoop : true,
			hideControlOnEnd : false,
			controls : false,
			speed : 1000,
			easing : 'easeOutExpo',
			pager : true,
			pagerSelector : null,
			pagerType : 'full',
			pagerLocation : 'top',
			pagerShortSeparator : '/',
			pagerActiveClass : 'pager-active',
			nextText : 'next',
			nextImage : '',
			nextSelector : null,
			prevText : 'prev',
			prevImage : '',
			prevSelector : null,
			captions : false,
			captionsSelector : null,
			auto : true,
			autoDirection : 'next',
			autoControls : false,
			autoControlsSelector : null,
			autoStart : true,
			autoHover : false,
			autoDelay : 0,
			pause : 5000,
			startText : 'start',
			startImage : '',
			stopText : 'stop',
			stopImage : '',
			ticker : false,
			tickerSpeed : 5000,
			tickerDirection : 'next',
			tickerHover : false,
			wrapperClass : 'bx-wrapper',
			startingSlide : 0,
			displaySlideQty : 1,
			moveSlideQty : 1,
			randomStart : false,
			onBeforeSlide : function() {
			},
			onAfterSlide : function() {
			},
			onLastSlide : function() {
			},
			onFirstSlide : function() {
			},
			onNextSlide : function() {
			},
			onPrevSlide : function() {
			},
			buildPager : null
		}
		var options = $.extend(defaults, options);
		var base = this;
		var $parent = '';
		var $origElement = '';
		var $children = '';
		var $outerWrapper = '';
		var $firstChild = '';
		var childrenWidth = '';
		var childrenOuterWidth = '';
		var wrapperWidth = '';
		var wrapperHeight = '';
		var $pager = '';
		var interval = '';
		var $autoControls = '';
		var $stopHtml = '';
		var $startContent = '';
		var $stopContent = '';
		var autoPlaying = true;
		var loaded = false;
		var childrenMaxWidth = 0;
		var childrenMaxHeight = 0;
		var currentSlide = 0;
		var origLeft = 0;
		var origTop = 0;
		var origShowWidth = 0;
		var origShowHeight = 0;
		var tickerLeft = 0;
		var tickerTop = 0;
		var isWorking = false;
		var firstSlide = 0;
		var lastSlide = $children.length - 1;
		this.goToSlide = function(number, stopAuto) {
			if (!isWorking) {
				isWorking = true;
				currentSlide = number;
				options.onBeforeSlide(currentSlide, $children.length, $children
						.eq(currentSlide));
				if (typeof (stopAuto) == 'undefined') {
					var stopAuto = true;
				}
				if (stopAuto) {
					if (options.auto) {
						base.stopShow(true);
					}
				}
				slide = number;
				if (slide == firstSlide) {
					options.onFirstSlide(currentSlide, $children.length,
							$children.eq(currentSlide));
				}
				if (slide == lastSlide) {
					options.onLastSlide(currentSlide, $children.length,
							$children.eq(currentSlide));
				}
				if (options.mode == 'horizontal') {
					$parent.animate( {
						'left' : '-' + getSlidePosition(slide, 'left') + 'px'
					}, options.speed, options.easing, function() {
						isWorking = false;
						options.onAfterSlide(currentSlide, $children.length,
								$children.eq(currentSlide));
					});
				} else if (options.mode == 'vertical') {
					$parent.animate( {
						'top' : '-' + getSlidePosition(slide, 'top') + 'px'
					}, options.speed, options.easing, function() {
						isWorking = false;
						options.onAfterSlide(currentSlide, $children.length,
								$children.eq(currentSlide));
					});
				} else if (options.mode == 'fade') {
					setChildrenFade();
				}
				checkEndControls();
				if (options.moveSlideQty > 1) {
					number = Math.floor(number / options.moveSlideQty);
				}
				makeSlideActive(number);
				showCaptions();
			}
		}
		this.goToNextSlide = function(stopAuto) {
			if (typeof (stopAuto) == 'undefined') {
				var stopAuto = true;
			}
			if (stopAuto) {
				if (options.auto) {
					base.stopShow(true);
				}
			}
			if (!options.infiniteLoop) {
				if (!isWorking) {
					var slideLoop = false;
					currentSlide = (currentSlide + (options.moveSlideQty));
					if (currentSlide <= lastSlide) {
						checkEndControls();
						options.onNextSlide(currentSlide, $children.length,
								$children.eq(currentSlide));
						base.goToSlide(currentSlide);
					} else {
						currentSlide -= options.moveSlideQty;
					}
				}
			} else {
				if (!isWorking) {
					isWorking = true;
					var slideLoop = false;
					currentSlide = (currentSlide + options.moveSlideQty);
					if (currentSlide > lastSlide) {
						currentSlide = currentSlide % $children.length;
						slideLoop = true;
					}
					options.onNextSlide(currentSlide, $children.length,
							$children.eq(currentSlide));
					options.onBeforeSlide(currentSlide, $children.length,
							$children.eq(currentSlide));
					if (options.mode == 'horizontal') {
						var parentLeft = (options.moveSlideQty * childrenOuterWidth);
						$parent.animate( {
							'left' : '-=' + parentLeft + 'px'
						}, options.speed, options.easing, function() {
							isWorking = false;
							if (slideLoop) {
								$parent.css('left', '-' + getSlidePosition(
										currentSlide, 'left') + 'px');
							}
							options.onAfterSlide(currentSlide,
									$children.length, $children
											.eq(currentSlide));
						});
					} else if (options.mode == 'vertical') {
						var parentTop = (options.moveSlideQty * childrenMaxHeight);
						$parent.animate( {
							'top' : '-=' + parentTop + 'px'
						}, options.speed, options.easing, function() {
							isWorking = false;
							if (slideLoop) {
								$parent.css('top', '-' + getSlidePosition(
										currentSlide, 'top') + 'px');
							}
							options.onAfterSlide(currentSlide,
									$children.length, $children
											.eq(currentSlide));
						});
					} else if (options.mode == 'fade') {
						setChildrenFade();
					}
					if (options.moveSlideQty > 1) {
						makeSlideActive(Math.ceil(currentSlide
								/ options.moveSlideQty));
					} else {
						makeSlideActive(currentSlide);
					}
					showCaptions();
				}
			}
		}
		this.goToPreviousSlide = function(stopAuto) {
			if (typeof (stopAuto) == 'undefined') {
				var stopAuto = true;
			}
			if (stopAuto) {
				if (options.auto) {
					base.stopShow(true);
				}
			}
			if (!options.infiniteLoop) {
				if (!isWorking) {
					var slideLoop = false;
					currentSlide = currentSlide - options.moveSlideQty;
					if (currentSlide < 0) {
						currentSlide = 0;
						if (options.hideControlOnEnd) {
							$('.bx-prev', $outerWrapper).hide();
						}
					}
					checkEndControls();
					options.onPrevSlide(currentSlide, $children.length,
							$children.eq(currentSlide));
					base.goToSlide(currentSlide);
				}
			} else {
				if (!isWorking) {
					isWorking = true;
					var slideLoop = false;
					currentSlide = (currentSlide - (options.moveSlideQty));
					if (currentSlide < 0) {
						negativeOffset = (currentSlide % $children.length);
						if (negativeOffset == 0) {
							currentSlide = 0;
						} else {
							currentSlide = ($children.length) + negativeOffset;
						}
						slideLoop = true;
					}
					options.onPrevSlide(currentSlide, $children.length,
							$children.eq(currentSlide));
					options.onBeforeSlide(currentSlide, $children.length,
							$children.eq(currentSlide));
					if (options.mode == 'horizontal') {
						var parentLeft = (options.moveSlideQty * childrenOuterWidth);
						$parent.animate( {
							'left' : '+=' + parentLeft + 'px'
						}, options.speed, options.easing, function() {
							isWorking = false;
							if (slideLoop) {
								$parent.css('left', '-' + getSlidePosition(
										currentSlide, 'left') + 'px');
							}
							options.onAfterSlide(currentSlide,
									$children.length, $children
											.eq(currentSlide));
						});
					} else if (options.mode == 'vertical') {
						var parentTop = (options.moveSlideQty * childrenMaxHeight);
						$parent.animate( {
							'top' : '+=' + parentTop + 'px'
						}, options.speed, options.easing, function() {
							isWorking = false;
							if (slideLoop) {
								$parent.css('top', '-' + getSlidePosition(
										currentSlide, 'top') + 'px');
							}
							options.onAfterSlide(currentSlide,
									$children.length, $children
											.eq(currentSlide));
						});
					} else if (options.mode == 'fade') {
						setChildrenFade();
					}
					if (options.moveSlideQty > 1) {
						makeSlideActive(Math.ceil(currentSlide
								/ options.moveSlideQty));
					} else {
						makeSlideActive(currentSlide);
					}
					showCaptions();
				}
			}
		}
		this.goToFirstSlide = function(stopAuto) {
			if (typeof (stopAuto) == 'undefined') {
				var stopAuto = true;
			}
			base.goToSlide(firstSlide, stopAuto);
		}
		this.goToLastSlide = function() {
			if (typeof (stopAuto) == 'undefined') {
				var stopAuto = true;
			}
			base.goToSlide(lastSlide, stopAuto);
		}
		this.getCurrentSlide = function() {
			return currentSlide;
		}
		this.getSlideCount = function() {
			return $children.length;
		}
		this.stopShow = function(changeText) {
			clearInterval(interval);
			if (typeof (changeText) == 'undefined') {
				var changeText = true;
			}
			if (changeText && options.autoControls) {
				$autoControls.html($startContent).removeClass('stop').addClass(
						'start');
				autoPlaying = false;
			}
		}
		this.startShow = function(changeText) {
			if (typeof (changeText) == 'undefined') {
				var changeText = true;
			}
			setAutoInterval();
			if (changeText && options.autoControls) {
				$autoControls.html($stopContent).removeClass('start').addClass(
						'stop');
				autoPlaying = true;
			}
		}
		this.stopTicker = function(changeText) {
			$parent.stop();
			if (typeof (changeText) == 'undefined') {
				var changeText = true;
			}
			if (changeText && options.ticker) {
				$autoControls.html($startContent).removeClass('stop').addClass(
						'start');
				autoPlaying = false;
			}
		}
		this.startTicker = function(changeText) {
			if (options.mode == 'horizontal') {
				if (options.tickerDirection == 'next') {
					var stoppedLeft = parseInt($parent.css('left'));
					var remainingDistance = (origShowWidth + stoppedLeft)
							+ $children.eq(0).width();
				} else if (options.tickerDirection == 'prev') {
					var stoppedLeft = -parseInt($parent.css('left'));
					var remainingDistance = (stoppedLeft)
							- $children.eq(0).width();
				}
				var finishingSpeed = (remainingDistance * options.tickerSpeed)
						/ origShowWidth;
				moveTheShow(tickerLeft, remainingDistance, finishingSpeed);
			} else if (options.mode == 'vertical') {
				if (options.tickerDirection == 'next') {
					var stoppedTop = parseInt($parent.css('top'));
					var remainingDistance = (origShowHeight + stoppedTop)
							+ $children.eq(0).height();
				} else if (options.tickerDirection == 'prev') {
					var stoppedTop = -parseInt($parent.css('top'));
					var remainingDistance = (stoppedTop)
							- $children.eq(0).height();
				}
				var finishingSpeed = (remainingDistance * options.tickerSpeed)
						/ origShowHeight;
				moveTheShow(tickerTop, remainingDistance, finishingSpeed);
				if (typeof (changeText) == 'undefined') {
					var changeText = true;
				}
				if (changeText && options.ticker) {
					$autoControls.html($stopContent).removeClass('start')
							.addClass('stop');
					autoPlaying = true;
				}
			}
		}
		this.initShow = function() {
			$parent = $(this);
			$origElement = $parent.clone();
			$children = $parent.children();
			$outerWrapper = '';
			$firstChild = $parent.children(':first');
			childrenWidth = $firstChild.width();
			childrenMaxWidth = 0;
			childrenOuterWidth = $firstChild.outerWidth();
			childrenMaxHeight = 0;
			wrapperWidth = getWrapperWidth();
			wrapperHeight = getWrapperHeight();
			isWorking = false;
			$pager = '';
			currentSlide = 0;
			origLeft = 0;
			origTop = 0;
			interval = '';
			$autoControls = '';
			$stopHtml = '';
			$startContent = '';
			$stopContent = '';
			autoPlaying = true;
			loaded = false;
			origShowWidth = 0;
			origShowHeight = 0;
			tickerLeft = 0;
			tickerTop = 0;
			firstSlide = 0;
			lastSlide = $children.length - 1;
			$children.each(function(index) {
				if ($(this).outerHeight() > childrenMaxHeight) {
					childrenMaxHeight = $(this).outerHeight();
				}
				if ($(this).outerWidth() > childrenMaxWidth) {
					childrenMaxWidth = $(this).outerWidth();
				}
			});
			if (options.randomStart) {
				var randomNumber = Math.floor(Math.random() * $children.length);
				currentSlide = randomNumber;
				origLeft = childrenOuterWidth
						* (options.moveSlideQty + randomNumber);
				origTop = childrenMaxHeight
						* (options.moveSlideQty + randomNumber);
			} else {
				currentSlide = options.startingSlide;
				origLeft = childrenOuterWidth
						* (options.moveSlideQty + options.startingSlide);
				origTop = childrenMaxHeight
						* (options.moveSlideQty + options.startingSlide);
			}
			initCss();
			if (options.pager && !options.ticker) {
				if (options.pagerType == 'full') {
					showPager('full');
				} else if (options.pagerType == 'short') {
					showPager('short');
				}
			}
			if (options.controls && !options.ticker) {
				setControlsVars();
			}
			if (options.auto || options.ticker) {
				if (options.autoControls) {
					setAutoControlsVars();
				}
				if (options.autoStart) {
					setTimeout(function() {
						base.startShow(true);
					}, options.autoDelay);
				} else {
					base.stopShow(true);
				}
				if (options.autoHover && !options.ticker) {
					setAutoHover();
				}
			}
			if (options.moveSlideQty > 1) {
				makeSlideActive(Math.ceil(currentSlide / options.moveSlideQty));
			} else {
				makeSlideActive(currentSlide);
			}
			checkEndControls();
			if (options.captions) {
				showCaptions();
			}
			options.onAfterSlide(currentSlide, $children.length, $children
					.eq(currentSlide));
		}
		this.destroyShow = function() {
			clearInterval(interval);
			$('.bx-next, .bx-prev, .bx-pager, .bx-auto', $outerWrapper)
					.remove();
			$parent.unwrap().unwrap().removeAttr('style');
			$parent.children().removeAttr('style').not('.pager').remove();
			$children.removeClass('pager');
		}
		this.reloadShow = function() {
			base.destroyShow();
			base.initShow();
		}
		function initCss() {
			setChildrenLayout(options.startingSlide);
			if (options.mode == 'horizontal') {
				$parent
						.wrap(
								'<div class="' + options.wrapperClass
										+ '" style="width:' + wrapperWidth
										+ 'px; position:relative;"></div>')
						.wrap(
								'<div class="bx-window" style="position:relative; overflow:hidden; width:' + wrapperWidth + 'px;"></div>')
						.css( {
							width : '999999px',
							position : 'relative',
							left : '-' + (origLeft) + 'px'
						});
				$parent.children().css( {
					width : childrenWidth,
					'float' : 'left',
					listStyle : 'none'
				});
				$outerWrapper = $parent.parent().parent();
				$children.addClass('pager');
			} else if (options.mode == 'vertical') {
				$parent
						.wrap(
								'<div class="' + options.wrapperClass
										+ '" style="width:' + childrenMaxWidth
										+ 'px; position:relative;"></div>')
						.wrap(
								'<div class="bx-window" style="width:'
										+ childrenMaxWidth
										+ 'px; height:'
										+ wrapperHeight
										+ 'px; position:relative; overflow:hidden;"></div>')
						.css( {
							height : '999999px',
							position : 'relative',
							top : '-' + (origTop) + 'px'
						});
				$parent.children().css( {
					listStyle : 'none',
					height : childrenMaxHeight
				});
				$outerWrapper = $parent.parent().parent();
				$children.addClass('pager');
			} else if (options.mode == 'fade') {
				$parent
						.wrap(
								'<div class="' + options.wrapperClass
										+ '" style="width:' + childrenMaxWidth
										+ 'px; position:relative;"></div>')
						.wrap(
								'<div class="bx-window" style="height:'
										+ childrenMaxHeight
										+ 'px; width:'
										+ childrenMaxWidth
										+ 'px; position:relative; overflow:hidden;"></div>');
				$parent.children().css( {
					listStyle : 'none',
					position : 'absolute',
					top : 0,
					left : 0,
					zIndex : 98
				});
				$outerWrapper = $parent.parent().parent();
				$children.not(':eq(' + currentSlide + ')').fadeTo(0, 0);
				$children.eq(currentSlide).css('zIndex', 99);
			}
			if (options.captions && options.captionsSelector == null) {
				$outerWrapper.append('<div class="bx-captions"></div>');
			}
		}
		function setChildrenLayout() {
			if (options.mode == 'horizontal' || options.mode == 'vertical') {
				var $prependedChildren = getArraySample($children, 0,
						options.moveSlideQty, 'backward');
				$.each($prependedChildren, function(index) {
					$parent.prepend($(this));
				});
				var totalNumberAfterWindow = ($children.length + options.moveSlideQty) - 1;
				var pagerExcess = $children.length - options.displaySlideQty;
				var numberToAppend = totalNumberAfterWindow - pagerExcess;
				var $appendedChildren = getArraySample($children, 0,
						numberToAppend, 'forward');
				if (options.infiniteLoop) {
					$.each($appendedChildren, function(index) {
						$parent.append($(this));
					});
				}
			}
		}
		function setControlsVars() {
			if (options.nextImage != '') {
				nextContent = options.nextImage;
				nextType = 'image';
			} else {
				nextContent = options.nextText;
				nextType = 'text';
			}
			if (options.prevImage != '') {
				prevContent = options.prevImage;
				prevType = 'image';
			} else {
				prevContent = options.prevText;
				prevType = 'text';
			}
			showControls(nextType, nextContent, prevType, prevContent);
		}
		function setAutoInterval() {
			if (options.auto) {
				if (!options.infiniteLoop) {
					if (options.autoDirection == 'next') {
						interval = setInterval(function() {
							currentSlide += options.moveSlideQty;
							if (currentSlide > lastSlide) {
								currentSlide = currentSlide % $children.length;
							}
							base.goToSlide(currentSlide, false);
						}, options.pause);
					} else if (options.autoDirection == 'prev') {
						interval = setInterval(
								function() {
									currentSlide -= options.moveSlideQty;
									if (currentSlide < 0) {
										negativeOffset = (currentSlide % $children.length);
										if (negativeOffset == 0) {
											currentSlide = 0;
										} else {
											currentSlide = ($children.length)
													+ negativeOffset;
										}
									}
									base.goToSlide(currentSlide, false);
								}, options.pause);
					}
				} else {
					if (options.autoDirection == 'next') {
						interval = setInterval(function() {
							base.goToNextSlide(false);
						}, options.pause);
					} else if (options.autoDirection == 'prev') {
						interval = setInterval(function() {
							base.goToPreviousSlide(false);
						}, options.pause);
					}
				}
			} else if (options.ticker) {
				options.tickerSpeed *= 10;
				$('.pager', $outerWrapper).each(function(index) {
					origShowWidth += $(this).width();
					origShowHeight += $(this).height();
				});
				if (options.tickerDirection == 'prev'
						&& options.mode == 'horizontal') {
					$parent
							.css('left',
									'-' + (origShowWidth + origLeft) + 'px');
				} else if (options.tickerDirection == 'prev'
						&& options.mode == 'vertical') {
					$parent.css('top', '-' + (origShowHeight + origTop) + 'px');
				}
				if (options.mode == 'horizontal') {
					tickerLeft = parseInt($parent.css('left'));
					moveTheShow(tickerLeft, origShowWidth, options.tickerSpeed);
				} else if (options.mode == 'vertical') {
					tickerTop = parseInt($parent.css('top'));
					moveTheShow(tickerTop, origShowHeight, options.tickerSpeed);
				}
				if (options.tickerHover) {
					setTickerHover();
				}
			}
		}
		function moveTheShow(leftCss, distance, speed) {
			if (options.mode == 'horizontal') {
				if (options.tickerDirection == 'next') {
					$parent.animate( {
						'left' : '-=' + distance + 'px'
					}, speed, 'linear',
							function() {
								$parent.css('left', leftCss);
								moveTheShow(leftCss, origShowWidth,
										options.tickerSpeed);
							});
				} else if (options.tickerDirection == 'prev') {
					$parent.animate( {
						'left' : '+=' + distance + 'px'
					}, speed, 'linear',
							function() {
								$parent.css('left', leftCss);
								moveTheShow(leftCss, origShowWidth,
										options.tickerSpeed);
							});
				}
			} else if (options.mode == 'vertical') {
				if (options.tickerDirection == 'next') {
					$parent.animate( {
						'top' : '-=' + distance + 'px'
					}, speed, 'linear', function() {
						$parent.css('top', leftCss);
						moveTheShow(leftCss, origShowHeight,
								options.tickerSpeed);
					});
				} else if (options.tickerDirection == 'prev') {
					$parent.animate( {
						'top' : '+=' + distance + 'px'
					}, speed, 'linear', function() {
						$parent.css('top', leftCss);
						moveTheShow(leftCss, origShowHeight,
								options.tickerSpeed);
					});
				}
			}
		}
		function setAutoControlsVars() {
			if (options.startImage != '') {
				startContent = options.startImage;
				startType = 'image';
			} else {
				startContent = options.startText;
				startType = 'text';
			}
			if (options.stopImage != '') {
				stopContent = options.stopImage;
				stopType = 'image';
			} else {
				stopContent = options.stopText;
				stopType = 'text';
			}
			showAutoControls(startType, startContent, stopType, stopContent);
		}
		function setAutoHover() {
			$outerWrapper.find('.bx-window').hover(function() {
				if (autoPlaying) {
					base.stopShow(false);
				}
			}, function() {
				if (autoPlaying) {
					base.startShow(false);
				}
			});
		}
		function setTickerHover() {
			$parent.hover(function() {
				if (autoPlaying) {
					base.stopTicker(false);
				}
			}, function() {
				if (autoPlaying) {
					base.startTicker(false);
				}
			});
		}
		function setChildrenFade() {
			$children.not(':eq(' + currentSlide + ')').fadeTo(options.speed, 0)
					.css('zIndex', 98);
			$children.eq(currentSlide).css('zIndex', 99).fadeTo(
					options.speed,
					1,
					function() {
						isWorking = false;
						if (jQuery.browser.msie) {
							$children.eq(currentSlide).get(0).style
									.removeAttribute('filter');
						}
						options.onAfterSlide(currentSlide, $children.length,
								$children.eq(currentSlide));
					});
		}
		;
		function makeSlideActive(number) {
			if (options.pagerType == 'full' && options.pager) {
				$('a', $pager).removeClass(options.pagerActiveClass);
				$('a', $pager).eq(number).addClass(options.pagerActiveClass);
			} else if (options.pagerType == 'short' && options.pager) {
				$('.bx-pager-current', $pager).html(currentSlide + 1);
			}
		}
		function showControls(nextType, nextContent, prevType, prevContent) {
			var $nextHtml = $('<a href="" class="bx-next"></a>');
			var $prevHtml = $('<a href="" class="bx-prev"></a>');
			if (nextType == 'text') {
				$nextHtml.html(nextContent);
			} else {
				$nextHtml.html('<img src="' + nextContent + '" />');
			}
			if (prevType == 'text') {
				$prevHtml.html(prevContent);
			} else {
				$prevHtml.html('<img src="' + prevContent + '" />');
			}
			if (options.prevSelector) {
				$(options.prevSelector).append($prevHtml);
			} else {
				$outerWrapper.append($prevHtml);
			}
			if (options.nextSelector) {
				$(options.nextSelector).append($nextHtml);
			} else {
				$outerWrapper.append($nextHtml);
			}
			$nextHtml.click(function() {
				base.goToNextSlide();
				return false;
			});
			$prevHtml.click(function() {
				base.goToPreviousSlide();
				return false;
			});
		}
		function showPager(type) {
			var pagerQty = $children.length;
			if (options.moveSlideQty > 1) {
				if ($children.length % options.moveSlideQty != 0) {
					pagerQty = Math.ceil($children.length
							/ options.moveSlideQty);
				} else {
					pagerQty = $children.length / options.moveSlideQty;
				}
			}
			var pagerString = '';
			if (options.buildPager) {
				for ( var i = 0; i < pagerQty; i++) {
					pagerString += options.buildPager(i, $children.eq(i
							* options.moveSlideQty));
				}
			} else if (type == 'full') {
				for ( var i = 1; i <= pagerQty; i++) {
					pagerString += '<a href="" class="pager-link pager-' + i
							+ '">' + i + '</a>';
				}
			} else if (type == 'short') {
				pagerString = '<span class="bx-pager-current">'
						+ (options.startingSlide + 1) + '</span> '
						+ options.pagerShortSeparator
						+ ' <span class="bx-pager-total">' + $children.length
						+ '<span>';
			}
			if (options.pagerSelector) {
				$(options.pagerSelector).append(pagerString);
				$pager = $(options.pagerSelector);
			} else {
				var $pagerContainer = $('<div class="bx-pager"></div>');
				$pagerContainer.append(pagerString);
				if (options.pagerLocation == 'top') {
					$outerWrapper.prepend($pagerContainer);
				} else if (options.pagerLocation == 'bottom') {
					$outerWrapper.append($pagerContainer);
				}
				$pager = $('.bx-pager', $outerWrapper);
			}
			$pager.children().click(function() {
				if (options.pagerType == 'full') {
					var slideIndex = $pager.children().index(this);
					if (options.moveSlideQty > 1) {
						slideIndex *= options.moveSlideQty;
					}
					base.goToSlide(slideIndex);
				}
				return false;
			});
		}
		function showCaptions() {
			var caption = $('img', $children.eq(currentSlide)).attr('title');
			if (caption != '') {
				if (options.captionsSelector) {
					$(options.captionsSelector).html(caption);
				} else {
					$('.bx-captions', $outerWrapper).html(caption);
				}
			} else {
				if (options.captionsSelector) {
					$(options.captionsSelector).html(' ');
				} else {
					$('.bx-captions', $outerWrapper).html(' ');
				}
			}
		}
		function showAutoControls(startType, startContent, stopType,
				stopContent) {
			$autoControls = $('<a href="" class="bx-start"></a>');
			if (startType == 'text') {
				$startContent = startContent;
			} else {
				$startContent = '<img src="' + startContent + '" />';
			}
			if (stopType == 'text') {
				$stopContent = stopContent;
			} else {
				$stopContent = '<img src="' + stopContent + '" />';
			}
			if (options.autoControlsSelector) {
				$(options.autoControlsSelector).append($autoControls);
			} else {
				$outerWrapper.append('<div class="bx-auto"></div>');
				$('.bx-auto', $outerWrapper).html($autoControls);
			}
			$autoControls.click(function() {
				if (options.ticker) {
					if ($(this).hasClass('stop')) {
						base.stopTicker();
					} else if ($(this).hasClass('start')) {
						base.startTicker();
					}
				} else {
					if ($(this).hasClass('stop')) {
						base.stopShow(true);
					} else if ($(this).hasClass('start')) {
						base.startShow(true);
					}
				}
				return false;
			});
		}
		function checkEndControls() {
			if (!options.infiniteLoop && options.hideControlOnEnd) {
				if (currentSlide == firstSlide) {
					$('.bx-prev', $outerWrapper).hide();
				} else {
					$('.bx-prev', $outerWrapper).show();
				}
				if (currentSlide == lastSlide) {
					$('.bx-next', $outerWrapper).hide();
				} else {
					$('.bx-next', $outerWrapper).show();
				}
			}
		}
		function getSlidePosition(number, side) {
			if (side == 'left') {
				var position = $('.pager', $outerWrapper).eq(number).position().left;
			} else if (side == 'top') {
				var position = $('.pager', $outerWrapper).eq(number).position().top;
			}
			return position;
		}
		function getWrapperWidth() {
			var wrapperWidth = $firstChild.outerWidth()
					* options.displaySlideQty;
			return wrapperWidth;
		}
		function getWrapperHeight() {
			var wrapperHeight = $firstChild.outerHeight()
					* options.displaySlideQty;
			return wrapperHeight;
		}
		function getArraySample(array, start, length, direction) {
			var sample = [];
			var loopLength = length;
			var startPopulatingArray = false;
			if (direction == 'backward') {
				array = $.makeArray(array);
				array.reverse();
			}
			while (loopLength > 0) {
				$.each(array, function(index, val) {
					if (loopLength > 0) {
						if (!startPopulatingArray) {
							if (index == start) {
								startPopulatingArray = true;
								sample.push($(this).clone());
								loopLength--;
							}
						} else {
							sample.push($(this).clone());
							loopLength--;
						}
					} else {
						return false;
					}
				});
			}
			return sample;
		}
		this.each(function() {
			base.initShow();
		});
		return this;
	}
	jQuery.fx.prototype.cur = function() {
		if (this.elem[this.prop] != null
				&& (!this.elem.style || this.elem.style[this.prop] == null)) {
			return this.elem[this.prop];
		}
		var r = parseFloat(jQuery.css(this.elem, this.prop));
		return r;
	}
})(jQuery);
