$.fn.evtslideshow.transition.horizontalSlide = {
	
	styles : {
		wrapperCSS : {
			position : 'relative',
			overflow : 'hidden'
		},
		innerCSS : {
			width : '100000px',
			position : 'absolute',
			top : 0,
			left: 0
		},
		slideCSS : {
			float: 'left'
		}
	},
	
	setUp : function( opts, callback )
	{
		opts.$wrapper.width( opts.$slides.eq(0).outerWidth() );
		opts.$wrapper.height( opts.$slides.eq(0).outerHeight() );

		if ( opts.atEnd === 'loop' )
		{
			opts.$slides.hide();
			opts.$slides.eq(opts.currentSlide).show();
		}
		else
		{
			var leftpos = opts.$slides.eq( opts.currentSlide ).position().left;
			opts.$wrapper.scrollLeft(leftpos);
		}
		callback();
	},
	
	action : function( opts, slideNum, callback )
	{
		var $sl		= opts.$slides,
			$from	= $sl.eq(opts.currentSlide),
			$to		= $sl.eq(slideNum),
			$wrap		= opts.$wrapper,
			slideWidth	= opts.$slides.eq(0).outerWidth();

		if ( opts.atEnd === 'loop' )
		{
			if ( opts.dir === 'prev' )
			{
				$from.before($to);
				$wrap.scrollLeft(slideWidth);
				$to.show();
				$wrap.animate( { scrollLeft : 0 }, opts.speed, function(){
					$from.hide();
					callback();
				});
			}
			else
			{
				$from.after($to);
				$to.show();
				$wrap.animate( { scrollLeft : slideWidth }, opts.speed, function(){
					$from.hide();
					$wrap.scrollLeft(0);
					callback();
				});
			}
		}
		else
		{
			var leftpos = opts.$slides.eq( slideNum ).position().left;
			opts.$wrapper.animate( { scrollLeft : leftpos }, opts.speed, callback );
		}
	}
};