Merge pull request #2798 from towolf/suspend-autorefresh-when-invisible
Disable auto-refresh when page is not visible
This commit is contained in:
commit
27867494ff
|
@ -105,6 +105,8 @@
|
|||
// Note: It is important that this is the first handler for this event!
|
||||
$(document).on('rendered', { self: this }, this.applyHandlers);
|
||||
|
||||
$(document).on('visibilitychange', { self: this }, this.onVisibilityChange);
|
||||
|
||||
$.each(this.icinga.behaviors, function (name, behavior) {
|
||||
behavior.bind($(document));
|
||||
});
|
||||
|
@ -172,6 +174,18 @@
|
|||
icinga.destroy();
|
||||
},
|
||||
|
||||
onVisibilityChange: function (event) {
|
||||
var icinga = event.data.self.icinga;
|
||||
|
||||
if (document.visibilityState === undefined || document.visibilityState === 'visible') {
|
||||
icinga.loader.autorefreshSuspended = false;
|
||||
icinga.logger.debug('Page visible, enabling auto-refresh');
|
||||
} else {
|
||||
icinga.loader.autorefreshSuspended = true;
|
||||
icinga.logger.debug('Page invisible, disabling auto-refresh');
|
||||
}
|
||||
},
|
||||
|
||||
/**
|
||||
* A scroll event happened in one of our containers
|
||||
*/
|
||||
|
@ -610,6 +624,7 @@
|
|||
$(document).off('change', 'form input.autosubmit', this.submitForm);
|
||||
$(document).off('focus', 'form select[data-related-radiobtn]', this.autoCheckRadioButton);
|
||||
$(document).off('focus', 'form input[data-related-radiobtn]', this.autoCheckRadioButton);
|
||||
$(document).off('visibilitychange', this.onVisibilityChange);
|
||||
},
|
||||
|
||||
destroy: function() {
|
||||
|
|
|
@ -30,7 +30,15 @@
|
|||
|
||||
this.iconCache = {};
|
||||
|
||||
/**
|
||||
* Whether auto-refresh is enabled
|
||||
*/
|
||||
this.autorefreshEnabled = true;
|
||||
|
||||
/**
|
||||
* Whether auto-refresh is suspended due to visibility of page
|
||||
*/
|
||||
this.autorefreshSuspended = false;
|
||||
};
|
||||
|
||||
Icinga.Loader.prototype = {
|
||||
|
@ -209,7 +217,7 @@
|
|||
|
||||
autorefresh: function () {
|
||||
var _this = this;
|
||||
if (_this.autorefreshEnabled !== true) {
|
||||
if (! _this.autorefreshEnabled || _this.autorefreshSuspended) {
|
||||
return;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue