-
Notifications
You must be signed in to change notification settings - Fork 1
/
ActivityMonitor.js
107 lines (90 loc) · 3.05 KB
/
ActivityMonitor.js
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
/**
* @class Ext.ux.ActivityMonitor
* @version 1.1
* @example
* Ext.ux.ActivityMonitor.init({ verbose : true });
* Ext.ux.ActivityMonitor.start();
**/
Ext.define('Ext.ux.ActivityMonitor', {
singleton: true,
ui: null,
runner: null,
task: null,
lastActive: null,
ready: false,
/** (Boolean): Whether or not the ActivityMonitor() should output messages to the JavaScript console. */
verbose: false,
/** interval (Integer): How often (in milliseconds) the monitorUI() method is executed after calling start() */
interval: (1000 * 60 * 1), // 1 minute
/** maxInactive (Integer): The longest amount of time to consider the user "active" without regestering new mouse movement or keystrokes */
maxInactive: (1000 * 60 * 5), // 5 minutes
/**
* isActive (Function): Called each time monitorUI() detects the user is currently active (defaults to Ext.emptyFn)
* the monitor is passed (this) as first argument
*/
isActive: Ext.emptyFn,
/**
* isInactive (Funtion): Called when monitorUI() detects the user is inactive (defaults to Ext.emptyFn)
* the monitor is passed (this) as first argument
*/
isInactive: Ext.emptyFn,
init: function(config) {
if (!config) { config = {}; }
Ext.apply(this, config, {
runner: new Ext.util.TaskRunner(),
ui: Ext.getBody(),
task: {
run: this.monitorUI,
interval: config.interval || this.interval,
scope: this
}
});
this.ready = true;
},
isReady: function() {
return this.ready;
},
start: function() {
if (!this.isReady()) {
this.log('Please run ActivityMonitor.init()');
return false;
}
this.ui.on('mousemove', this.captureActivity, this);
this.ui.on('keydown', this.captureActivity, this);
this.lastActive = new Date();
this.log('ActivityMonitor has been started.');
this.runner.start(this.task);
},
stop: function() {
if (!this.isReady()) {
this.log('Please run ActivityMonitor.init()');
return false;
}
this.runner.stop(this.task);
this.lastActive = null;
this.ui.un('mousemove', this.captureActivity);
this.ui.un('keydown', this.captureActivity);
this.log('ActivityMonitor has been stopped.');
},
captureActivity: function(eventObj, el, eventOptions) {
this.lastActive = new Date();
},
monitorUI: function() {
var now = new Date();
var inactive = (now - this.lastActive);
if (inactive >= this.maxInactive) {
this.log('MAXIMUM INACTIVE TIME HAS BEEN REACHED');
this.stop(); //remove event listeners
this.isInactive(this);
}
else {
this.log('CURRENTLY INACTIVE FOR ' + inactive + ' (ms)');
this.isActive(this);
}
},
log: function(msg) {
if (this.verbose) {
window.console.log(msg);
}
}
});