forked from extern/egroupware
* Notifications: do not fire another notification request unless the last one has been responded. In case of failure increase amount of polling interval.
This commit is contained in:
parent
811444dc98
commit
71a263386c
@ -61,16 +61,50 @@
|
|||||||
*/
|
*/
|
||||||
const EGW_PR_NOTIFY_LOW = 3;
|
const EGW_PR_NOTIFY_LOW = 3;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interval set by user
|
||||||
|
* @type Number
|
||||||
|
*/
|
||||||
|
var POLL_INTERVAL = 60;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current interval set by system (gets increased by factor of 2 in case of request failure)
|
||||||
|
* @type Number
|
||||||
|
*/
|
||||||
|
var CURRENT_INTERVAL = 60;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current timeout ID
|
||||||
|
* @type Number
|
||||||
|
*/
|
||||||
|
var TIMEOUT = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor inits polling and installs handlers, polling frequence is passed via data-poll-interval of script tag
|
* Constructor inits polling and installs handlers, polling frequence is passed via data-poll-interval of script tag
|
||||||
*/
|
*/
|
||||||
function notifications() {
|
function notifications() {
|
||||||
var notification_script = document.getElementById('notifications_script_id');
|
var notification_script = document.getElementById('notifications_script_id');
|
||||||
var popup_poll_interval = notification_script && notification_script.getAttribute('data-poll-interval');
|
CURRENT_INTERVAL = POLL_INTERVAL = notification_script && notification_script.getAttribute('data-poll-interval');
|
||||||
this.setTimeout(popup_poll_interval || 60);
|
TIMEOUT = this.setTimeout(POLL_INTERVAL || 60);
|
||||||
jQuery('#notificationbell').click(jQuery.proxy(this.display, this));
|
jQuery('#notificationbell').click(jQuery.proxy(this.display, this));
|
||||||
// query notifictions now
|
// query notifictions now
|
||||||
this.get_notifications();
|
this.run_notifications();
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
notifications.prototype.run_notifications = function ()
|
||||||
|
{
|
||||||
|
var self = this;
|
||||||
|
this.get_notifications().then(function(){
|
||||||
|
window.clearTimeout(TIMEOUT);
|
||||||
|
self.check_browser_notify();
|
||||||
|
TIMEOUT = self.setTimeout(POLL_INTERVAL);
|
||||||
|
},
|
||||||
|
function(){
|
||||||
|
window.clearTimeout(TIMEOUT);
|
||||||
|
CURRENT_INTERVAL *= 2;
|
||||||
|
self.setTimeout(CURRENT_INTERVAL);
|
||||||
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -78,10 +112,18 @@
|
|||||||
*/
|
*/
|
||||||
notifications.prototype.get_notifications = function()
|
notifications.prototype.get_notifications = function()
|
||||||
{
|
{
|
||||||
|
var self = this;
|
||||||
|
return new Promise (function(_resolve, _reject){
|
||||||
egw.json(
|
egw.json(
|
||||||
"notifications.notifications_ajax.get_notifications",
|
"notifications.notifications_ajax.get_notifications",[],
|
||||||
this.check_browser_notify()
|
function(){
|
||||||
).sendRequest(true);
|
_resolve();
|
||||||
|
self.check_browser_notify()
|
||||||
|
}).sendRequest(true,'POST', function(_err){
|
||||||
|
if (_err && _err.statusText) egw.message(_err.statusText);
|
||||||
|
_reject();
|
||||||
|
});
|
||||||
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -90,9 +132,8 @@
|
|||||||
*/
|
*/
|
||||||
notifications.prototype.setTimeout = function(_i) {
|
notifications.prototype.setTimeout = function(_i) {
|
||||||
var self = this;
|
var self = this;
|
||||||
window.setTimeout(function(){
|
return window.setTimeout(function(){
|
||||||
self.get_notifications();
|
self.run_notifications();
|
||||||
self.setTimeout(_i);
|
|
||||||
}, _i*1000);
|
}, _i*1000);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user