diff --git a/IPython/html/static/tree/js/main.js b/IPython/html/static/tree/js/main.js index 659b50ddc..2bdb089aa 100644 --- a/IPython/html/static/tree/js/main.js +++ b/IPython/html/static/tree/js/main.js @@ -82,26 +82,39 @@ require([ var interval_id=0; // auto refresh every xx secondes, no need to be fast, - // update is done at least when page get focus - var time_refresh = 60; // in sec + // update is done most of the time when page get focus + IPython.tree_time_refresh = 60; // in sec - var enable_autorefresh = function(){ - /** - *refresh immediately , then start interval - */ + // limit refresh on focus at 1/10sec, otherwise this + // can cause too frequent refresh on switching through windows or tabs. + IPython.min_delta_refresh = 10; // in sec + + var _last_refresh = null; + + var _refresh_list = function(){ + _last_refresh = new Date(); session_list.load_sessions(); cluster_list.load_list(); if (terminal_list) { terminal_list.load_terminals(); } + } + + var enable_autorefresh = function(){ + /** + *refresh immediately , then start interval + */ + var now = new Date() + + if (now - _last_refresh < IPython.min_delta_refresh*1000){ + console.log("Reenabling autorefresh too close to last tree refresh, not refreshing immediately again.") + } else { + _refresh_list(); + } if (!interval_id){ - interval_id = setInterval(function(){ - session_list.load_sessions(); - cluster_list.load_list(); - if (terminal_list) { - terminal_list.load_terminals(); - } - }, time_refresh*1000); + interval_id = setInterval(_refresh_list, + IPython.tree_time_refresh*1000 + ); } };