summaryrefslogtreecommitdiff
path: root/chimere/static/jme/utils/useractivity.js
blob: 862996dd9455fcfc41fb7721be3d6e9d474fe69b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
(function($){
	/**
	 * helps you to detect user activity/userinactivity in an html-area
	 * 
	 *  usage:
	 *  
	 *  $('div.my-element')
	 *  	.bind('useractive', function(e){
	 *  		// user is active in this area
	 *  	})
	 *  	.bind('userinactive', function(e){
	 *  		// user is inactive in this area
	 *  	})
	 *  ;
	 *  
	 *  more advanced usage:
	 *  
	 *  $('div.my-element')
	 *  	.bind('useractive', function(e){
	 *  		// user is active in this area
	 *  	})
	 *  	.bind('userinactive', {idletime: 1500}, function(e){
	 *  		// user is inactive in this area
	 *  	})
	 *  ;
	 */
	if(!$.support.opacity && !$.opacityRemoveFix){
		var oldStyle = $.style;
		$.style = function(elem, name, value){
			var ret = oldStyle(elem, name, value);
			if(name === 'opacity' && value == 1){
				elem.style.filter = (elem.style.filter || '').replace('alpha(opacity=100)', '');
			}
			return ret;
		};
		$.opacityRemoveFix = true;
	}
	var activity = {
		add: function(elem, cfg, name){
			var data 		= $.data(elem, 'jmeuseractivity') || $.data(elem, 'jmeuseractivity', {idletime: 2500, idle: true, trigger: {}}),
				jElm 		= $(elem),
				setInactive = function(){
					if(!data.idle){
						data.idle = true;
						if ( data.trigger.userinactive ) {
							jElm.trigger('userinactive');
						}
					}
				},
				setActive 	= function(e){
					if(!e || (e.type === 'mousemove' && e.pageX === x && e.pageY === y)){return;}
					if(e.type === 'mousemove'){
						 x = e.pageX;
						 y = e.pageY;
					}
					if(data.idleTimer){
						clearTimeout(data.idleTimer);
					}
					data.idleTimer = setTimeout(setInactive, data.idletime);
					if(data.idle){
						data.idle = false;
						if( data.trigger.useractive ){
							jElm.trigger('useractive');
						}
					}
				},
				x, y
			;
			
			data.idletime = (cfg || {}).idletime || data.idletime;
			if(cfg && 'idle' in cfg){
				data.idle = cfg.idle;
			}
			data.trigger[name] = true;
			
			if( !data.bound ){
				jElm
					.bind('mouseleave.jmeuseractivity', setInactive)
					.bind('mousemove.jmeuseractivity focusin.jmeuseractivity mouseenter.jmeuseractivity keydown.jmeuseractivity keyup.jmeuseractivity mousedown.jmeuseractivity', setActive)
				;
				data.bound = true;
			}
			if(!data.idle){
				setActive({type: 'initunidled'});
			}
		},
		remove: function(elem, name){
			var data = $.data(elem, 'jmeuseractivity') || $.data(elem, 'jmeuseractivity', {idletime: 2500, idle: true, trigger: {}});
			data.trigger[name] = false;
			if(!data.trigger.useractive && !data.trigger.userinactive){
				$(elem).unbind('.jmeuseractivity');
				data.bound = false;
			}
		}
	};
	$.each(['useractive', 'userinactive'], function(i, name){
		$.event.special[name] = {
			setup: function(cfg){
				activity.add(this, cfg, name);
			},
			teardown: function(){
				activity.remove(this, name);
			}
		};
	});
	
	
})(jQuery);