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
|
// Uses long-polling to update a div with id=#{updating}
// The gethtml route should return a new div, with the same id.
//
// Maximum update frequency is controlled by #{startdelay}
// and #{delay}, both in milliseconds.
(function( $ ) {
numerrs=0;
$.LongPoll = (function() {
return {
send : function() {
$.ajax({
'url': '@{gethtml}',
'dataType': 'html',
'success': function(data, status, jqxhr) {
$('##{updating}').replaceWith(data);
setTimeout($.LongPoll.send, #{delay});
numerrs=0;
},
'error': function(jqxhr, msg, e) {
numerrs=numerrs+1;
if (numerrs > 3) {
window.close();
}
else {
setTimeout($.LongPoll.send, #{delay});
}
},
});
}
}
}());
$(document).bind('ready.app', function() {
setTimeout($.LongPoll.send, #{startdelay});
});
})( jQuery );
|