jQuery(function($) {

	$.fn.ProbandoTimer = function(settings) {
		return "Hola";
	};

	$.ProbandoTimer = function(settings) {
		alert ("hola");;
	};

	$.everyTime = function(interval, label, fn, times, belay) {
		return this.each(function() {
			timer.add(this, interval, label, fn, times, belay);
		});
	};

	$.oneTime = function(interval, label, fn) {
				return this.each(function() {
					timer.add(this, interval, label, fn, 1);
				});
	};

	stopTime= function(label, fn) {
				 return this.each(function() {
					 timer.remove(this, label, fn);
				 });
			 };


var 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 = 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)
					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 = timer.global;
		for ( var label in global ) {
			var els = global[label], i = els.length;
			while ( --i )
				timer.remove(els[i], label);
		}
	});




	jQuery.fn.extend({
		
everyTime: function(interval, label, fn, times, belay) {
               return this.each(function() {
                   timer.add(this, interval, label, fn, times, belay);
               });
           },
oneTime: function(interval, label, fn) {
               return this.each(function() {
                   timer.add(this, interval, label, fn, 1);
               });
           },
stopTime: function(label, fn) {
               return this.each(function() {
                   timer.remove(this, label, fn);
               });
           },

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 = 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)
                      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;
              }
          }
       }
});


});
