2 * jQuery.timers - Timer abstractions for jQuery
\r
3 * Written by Blair Mitchelmore (blair DOT mitchelmore AT gmail DOT com)
\r
4 * Licensed under the WTFPL (http://sam.zoy.org/wtfpl/).
\r
7 * @author Blair Mitchelmore
\r
13 everyTime: function(interval, label, fn, times, belay) {
\r
14 return this.each(function() {
\r
15 jQuery.timer.add(this, interval, label, fn, times, belay);
\r
18 oneTime: function(interval, label, fn) {
\r
19 return this.each(function() {
\r
20 jQuery.timer.add(this, interval, label, fn, 1);
\r
23 stopTime: function(label, fn) {
\r
24 return this.each(function() {
\r
25 jQuery.timer.remove(this, label, fn);
\r
34 regex: /^([0-9]+)\s*(.*s)?$/,
\r
36 // Yeah this is major overkill...
\r
45 timeParse: function(value) {
\r
46 if (value == undefined || value == null)
\r
48 var result = this.regex.exec(jQuery.trim(value.toString()));
\r
50 var num = parseInt(result[1], 10);
\r
51 var mult = this.powers[result[2]] || 1;
\r
57 add: function(element, interval, label, fn, times, belay) {
\r
60 if (jQuery.isFunction(label)) {
\r
67 interval = jQuery.timer.timeParse(interval);
\r
69 if (typeof interval != 'number' || isNaN(interval) || interval <= 0)
\r
72 if (times && times.constructor != Number) {
\r
78 belay = belay || false;
\r
80 if (!element.$timers)
\r
81 element.$timers = {};
\r
83 if (!element.$timers[label])
\r
84 element.$timers[label] = {};
\r
86 fn.$timerID = fn.$timerID || this.guid++;
\r
88 var handler = function() {
\r
89 if (belay && this.inProgress)
\r
91 this.inProgress = true;
\r
92 if ((++counter > times && times !== 0) || fn.call(element, counter) === false)
\r
93 jQuery.timer.remove(element, label, fn);
\r
94 this.inProgress = false;
\r
97 handler.$timerID = fn.$timerID;
\r
99 if (!element.$timers[label][fn.$timerID])
\r
100 element.$timers[label][fn.$timerID] = window.setInterval(handler,interval);
\r
102 if ( !this.global[label] )
\r
103 this.global[label] = [];
\r
104 this.global[label].push( element );
\r
107 remove: function(element, label, fn) {
\r
108 var timers = element.$timers, ret;
\r
113 for ( label in timers )
\r
114 this.remove(element, label, fn);
\r
115 } else if ( timers[label] ) {
\r
117 if ( fn.$timerID ) {
\r
118 window.clearInterval(timers[label][fn.$timerID]);
\r
119 delete timers[label][fn.$timerID];
\r
122 for ( var fn in timers[label] ) {
\r
123 window.clearInterval(timers[label][fn]);
\r
124 delete timers[label][fn];
\r
128 for ( ret in timers[label] ) break;
\r
131 delete timers[label];
\r
135 for ( ret in timers ) break;
\r
137 element.$timers = null;
\r
143 if (jQuery.browser.msie)
\r
144 jQuery(window).one("unload", function() {
\r
145 var global = jQuery.timer.global;
\r
146 for ( var label in global ) {
\r
147 var els = global[label], i = els.length;
\r
149 jQuery.timer.remove(els[i], label);
\r