aboutsummaryrefslogtreecommitdiffstats
path: root/interface
diff options
context:
space:
mode:
authorAlexander Moisseev <moiseev@mezonplus.ru>2016-12-31 20:58:07 +0300
committerAlexander Moisseev <moiseev@mezonplus.ru>2016-12-31 21:14:36 +0300
commitbcbc086688dece22a9af75c03376e839ead6051e (patch)
tree89f71f2c0418c096050db3842ea3642029857a11 /interface
parentd0da131c5e53f5e3080cbf67b4d95fd3fa04bad5 (diff)
downloadrspamd-bcbc086688dece22a9af75c03376e839ead6051e.tar.gz
rspamd-bcbc086688dece22a9af75c03376e839ead6051e.zip
[WebUI] Use unified tab click event handler,
stop refreshing widgets on hidden tabs, make `refresh` button functional for some more tabs
Diffstat (limited to 'interface')
-rw-r--r--interface/js/rspamd.js91
1 files changed, 49 insertions, 42 deletions
diff --git a/interface/js/rspamd.js b/interface/js/rspamd.js
index 6f3fc5040..2ea7eeca7 100644
--- a/interface/js/rspamd.js
+++ b/interface/js/rspamd.js
@@ -51,7 +51,7 @@
graph.interpolate(this.value);
});
- $('#disconnect').on('click', function (event) {
+ function disconnect() {
if (pie) {
pie.destroy();
}
@@ -74,24 +74,52 @@
connectRSPAMD();
// window.location.reload();
return false;
- });
- $('#refresh').on('click', function (event) {
- if (!$(this).attr('disabled')) {
- $(this).attr('disabled', true);
- Visibility.stop(stat_timeout);
+ }
- statWidgets();
- stat_timeout = Visibility.every(10000, function () {
- statWidgets();
- });
- getChart();
- getGraphData(selected.selData);
+ function tabClick(tab_id) {
+ if ($(tab_id).attr('disabled')) return;
+ $(tab_id).attr('disabled', true);
- setTimeout(function () {
- $('#refresh').removeAttr('disabled');
- }, 1000);
+ Visibility.stop(stat_timeout);
+
+ if (tab_id === "#refresh") {
+ tab_id = "#" + $('.navbar-nav .active > a' ).attr('id');
}
- });
+
+ switch (tab_id) {
+ case "#status_nav":
+ statWidgets();
+ stat_timeout = Visibility.every(10000, function () {
+ statWidgets();
+ });
+ getChart();
+ break;
+ case "#throughput_nav":
+ getGraphData(selected.selData);
+ break;
+ case "#configuration_nav":
+ getActions();
+ $('#modalBody').empty();
+ getMaps();
+ break;
+ case "#symbols_nav":
+ getSymbols();
+ break;
+ case "#history_nav":
+ getHistory();
+ getErrors();
+ break;
+ case "#disconnect":
+ disconnect();
+ break;
+ }
+
+ setTimeout(function () {
+ $(tab_id).removeAttr('disabled');
+ $('#refresh').removeAttr('disabled');
+ }, 1000);
+ }
+
// @supports session storage
function supportsSessionStorage() {
return typeof (Storage) !== "undefined";
@@ -1265,18 +1293,11 @@
function displayUI() {
// @toggle auth and main
var disconnect = $('#navBar .pull-right');
- statWidgets();
- stat_timeout = Visibility.every(10000, function () {
- statWidgets();
- });
$('#mainUI').show();
$('#progress').show();
- getChart();
initGraph();
- if ($("#throughput_nav").attr("aria-expanded") === "true") {
- getGraphData(selected.selData);
- }
+ tabClick("#refresh");
$('#progress').hide();
$(disconnect).show();
@@ -1284,12 +1305,6 @@
connectRSPAMD();
- $('#configuration_nav').bind('click', function (e) {
- getActions();
- $('#modalBody').empty();
- getMaps();
- });
-
$(document).ajaxStart(function () {
$('#navBar').addClass('loading');
});
@@ -1298,18 +1313,10 @@
$('#navBar').removeClass('loading');
}, 1000);
});
- $('#status_nav').bind('click', function (e) {
- getChart();
- });
- $('#throughput_nav').bind('click', function () {
- getGraphData(selected.selData);
- });
- $('#history_nav').bind('click', function () {
- getHistory();
- getErrors();
- });
- $('#symbols_nav').bind('click', function () {
- getSymbols();
+
+ $('a[data-toggle="tab"]').on('click', function (e) {
+ const tab_id = "#" + $(e.target).attr("id")
+ tabClick(tab_id);
});
});
})();