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);
		}
	});



(function(jQuery){
    jQuery.fn.vjachetGallery = function(options) {
        options = jQuery.extend({
            count: 6
        }, options);
        var folder
        var count
        var cur
        next = function(obj) {
            folder = obj.attr('folder')
            count  = obj.attr('count')
            cur = obj.attr('cur')
            ++cur
            if (cur > count) cur = 1
            obj.parent('div').children('img:eq(1)').attr('src', folder + '0' + cur + '.png')
            obj.attr('cur', cur)
        }
        return this.each(function () {
            var reload = true
            var self = jQuery(this);
			var count  = self.attr('count')
			var path
            self.parent().css({'position':'relative'})
			
			
            numbers = $('<div></div>').appendTo(self.parent()).css({'position':'absolute','top':self.height() - 28, left:self.width() -50})
            
            for (var i = 1; i <= count; ++i) {
                $('<a href="#" style="text-decoration:none;padding-right:4px;color:#000;">'+i+'</a>').css({'color':'#FFF'}).click(function() {
                    var num = $(this).text()
					
                    self.stopTime()
					folder = self.attr('folder')
                    self.css({'opacity': 1})
                    self.parent('div').children('img:eq(1)').css({'opacity': 0})
					path = folder + '0' + num + '.png'
                    self.parent('div').children('img:eq(1)').attr('src', path)
					self.attr('cur', num)
					//self.oneTime(2000, function() {next(self);})
                    return false
                }).appendTo(numbers)
            }
            self.bind('load' , function() {
                if (!reload) return false;
                self.css({'opacity': 1}, 200)
                self.parent('div').children('img:eq(1)').css({'opacity': 0}, 200)
                self.oneTime(2000, function() {next(self);})
                reload = false
            })
            self.parent('div').children('img:eq(1)').css({'opacity' : 0})
            self.parent('div').children('img:eq(1)').bind('load', function() {
                if (self.parent('div').children('img:eq(1)').hasClass('begin')) {
                    reload = false
                    self.parent('div').children('img:eq(1)').animate({'opacity': 1}, 1500)
                    self.animate({'opacity' : 0}, 1500, function() {
                        self.attr('src', self.parent('div').children('img:eq(1)').attr('src'))
                        reload= true
                    })
                }
                self.parent('div').children('img:eq(1)').addClass('begin')
            })
        });
    };
})(jQuery);
$(function() {
   $('.gal').vjachetGallery({count:6})
})


