jQuery.fn.gallery = function(s,slideshow,styling) {	
		var gallery = this;
		var img = [];
		var link = [];
		var currentImage = 0;
		var speed = 1000; if(s) speed = parseInt(s,10);
		var ssOption = '<li><a href="#" id="playstop" title="Play/Stop SlideShow">&nbsp;</a></li>';
		var take = 0;
		if(slideshow==undefined) {
			slideShowSpeed = speed*5.0;
		} else if(slideshow) {
			slideShowSpeed = slideshow;
		} else if (!slideshow) {
			ssOption = '';
			take = 1;
		}
		var galleryStructure = '<div id="img-gallery"><a href="#" class="link"><img style="display:none" /></a><ul id="quick">'+ssOption+'</ul><div id="img-description"></div></div>';
		var started = false;
		$j(gallery).each(function(i){
			$j(this).hide();
			
			var link = $j(this).parent().attr('href').toString();
			//console.log(link);
			img[i] = [this.src,this.alt,$j(this).attr('longdesc'), link];
			
			//console.log(img);
			this.onload = function(){
				$j(this).remove();
			}
			gallery[gallery.length-1].onload = function(){
				$j(this).remove();
				start();
				started = true;
			}
			setTimeout(function(){
				if(!started) start();
			},2000)
		})
		function start(){
			
			// EDITABLE:
			$j('div.gallery_holder').prepend(galleryStructure); // DESTINATION OF GALLERY (YOU CAN CHANGE THIS)
			// --------
			
			$j(img).each(function(i){
				$j('#img-gallery ul').append('<li><a href="#img' + (i + 1) + '">' + (i + 1) + '</a></li>');
			})
			changeImage(0);
			$j('#img-gallery ul a:not(#playstop)').click(function(){
				var imgToLoad = $j(this).attr('href');
				imgToLoad = imgToLoad.split('#');
				imgToLoad = parseInt(imgToLoad[1].substr(3)) - 1;
				//if (imgToLoad >= gallery.length) { imgToLoad = 0; }
				currentImage = imgToLoad + 1;
				changeImage(imgToLoad);
				clearTimeout(window['galleryTimeout']);
				window['galleryTimeout'] = setTimeout(function(){startSlideShow()}, slideShowSpeed)
				if(window['ssr']) $j('#img-gallery ul a#playstop').click();
				return false;
			})
			
$j('#img-gallery ul a#playstop').toggle(
   function(){
      if(gallery.length > 1){
         $j(this).toggleClass('stop');
         stopSlideShow();
         return false;
      }else{
         $j(this).toggleClass('stop');
         startSlideShow();
         return false;
      }
   },
   function(){
      if(gallery.length > 1){
         $j(this).toggleClass('stop');
         startSlideShow();
         return false;
      }else{
         $j(this).toggleClass('stop');
         stopSlideShow();
         return false;	
      }
   }
);

if(gallery.length > 1){
   $j('#img-gallery ul a#playstop').toggleClass('stop');
   startSlideShow();
}
			function changeImage(n, callback){
			
				//$('#img-gallery #img-description').fadeOut(speed / 5);
				$j('#img-gallery img').fadeOut(speed / 4, function(){
					var originalWidth = $j('#img-gallery img').width();
					$j('#img-gallery img').attr('src', img[n][0]).attr('alt', img[n][1]);
					$j('#img-gallery a.link').attr('href', img[n][3]);
					var width = $j('#img-gallery img').width();
					var height = $j('#img-gallery img').height();
					fadeInAll();
					//if (width == originalWidth) { fadeInAll(); } else { animate(); }
					function animate() {
						$j('#img-gallery ul').hide();
						return false;
						$j('#img-gallery ul').fadeOut(speed / 2, function(){
							$j('#img-gallery').animate({
								width: width,
								height: height
							}, speed / 2, function(){
								fadeInAll(true)
							})
						})
					}
					function fadeInAll(fromAnimate){
						var localSpeed = speed;
						if (!fromAnimate) 
							localSpeed = speed / 2;
						//$('#img-gallery #img-description').html('<p>' + img[n][2] + '</p>');
						//$('#img-gallery #img-description').fadeIn();
						$j('#img-gallery img').fadeIn(localSpeed / 2);
						//$('#img-gallery ul').fadeIn(localSpeed / 2);
						$j('#img-gallery ul').show();
						$j('#img-gallery ul a:eq(' + (n + 1 - take) + ')').addClass('active');
						if (callback) callback();
						if (styling) styling();
					}
				})
				$j('#img-gallery ul a').removeClass('active');
				
				if (img[n][2] == undefined) {
					//$('#img-gallery #img-description').hide();
				}
				else {
					//$('#img-gallery #img-description').show();
				}
			}
			function startSlideShow(){
				 imgToLoad = currentImage;
				 if (imgToLoad >= gallery.length) {imgToLoad = 0;currentImage = 0;}
				 window['galleryTimeout'] = setTimeout(function(){startSlideShow()}, slideShowSpeed)
				 //alert(imgToLoad);
				 changeImage(imgToLoad, function(){eval(galleryTimeout);});
				 currentImage++;
/*
				var imgToLoad = $('#img-gallery ul a.active:eq(0)').attr('href');

				imgToLoad = imgToLoad.split('#');
				window['ssr'] = true;
				imgToLoad = parseInt(imgToLoad[1].substr(3));
				if (imgToLoad == gallery.length) {
					imgToLoad = 0;
				}
				window['galleryTimeout'] = setTimeout(function(){
					startSlideShow()
				}, slideShowSpeed)
				changeImage(imgToLoad, function(){
					eval(galleryTimeout);
				});
*/
			}
			function stopSlideShow(){
				window['ssr'] = false;
				clearTimeout(eval(galleryTimeout));
			}
			
/*			$(document).ready(function(){

			});
*/
		}
}
