diff options
author | Jo-Philipp Wich <jo@mein.io> | 2020-02-22 23:32:44 +0100 |
---|---|---|
committer | Jo-Philipp Wich <jo@mein.io> | 2020-02-22 23:32:44 +0100 |
commit | 72da3c4c5509a4fe9d779e03d76a97854022fafe (patch) | |
tree | 522e458f156264443fdfe2a13d52f2a53c3c9f1d /applications/luci-app-statistics/htdocs/luci-static/resources/statistics/rrdtool.js | |
parent | d4a475163e0fd87f5ade7a46b075a119178ae24a (diff) |
luci-app-statistics: rearrange graph display
- Add a per-plugin overview tab that contains the (non-detail) graphs of
each plugin instance, similar to the old Lua based implementation
- Numerically order plugin instances starting with numbers
- Avoid multiple renderings of the same graphs
- Fix legend of tcpconns graphs
- Move cpufreq distribution and transition charts to detail tabs
Signed-off-by: Jo-Philipp Wich <jo@mein.io>
Diffstat (limited to 'applications/luci-app-statistics/htdocs/luci-static/resources/statistics/rrdtool.js')
-rw-r--r-- | applications/luci-app-statistics/htdocs/luci-static/resources/statistics/rrdtool.js | 42 |
1 files changed, 38 insertions, 4 deletions
diff --git a/applications/luci-app-statistics/htdocs/luci-static/resources/statistics/rrdtool.js b/applications/luci-app-statistics/htdocs/luci-static/resources/statistics/rrdtool.js index fbb5da626d..00b65d5b6d 100644 --- a/applications/luci-app-statistics/htdocs/luci-static/resources/statistics/rrdtool.js +++ b/applications/luci-app-statistics/htdocs/luci-static/resources/statistics/rrdtool.js @@ -259,7 +259,17 @@ return L.Class.extend({ }, pluginInstances: function(hostInstance, pluginName) { - return Object.keys((rrdtree[hostInstance] || {})[pluginName] || {}).sort(); + return Object.keys((rrdtree[hostInstance] || {})[pluginName] || {}).sort(function(a, b) { + var x = a.match(/^(\d+)\b/), + y = b.match(/^(\d+)\b/); + + if (!x != !y) + return !x - !y; + else if (x && y && x[0] != y[0]) + return +x[0] - +y[0]; + else + return a > b; + }); }, dataTypes: function(hostInstance, pluginName, pluginInstance) { @@ -279,6 +289,21 @@ return L.Class.extend({ return (graphdefs[pluginName] != null); }, + hasInstanceDetails: function(hostInstance, pluginName, pluginInstance) { + var def = graphdefs[pluginName]; + + if (!def || typeof(def.rrdargs) != 'function') + return false; + + var optlist = this._forcelol(def.rrdargs(this, hostInstance, pluginName, pluginInstance, null, false)); + + for (var i = 0; i < optlist.length; i++) + if (optlist[i].detail) + return true; + + return false; + }, + _mkpath: function(host, plugin, plugin_instance, dtype, data_instance) { var path = host + '/' + plugin; @@ -304,7 +329,7 @@ return L.Class.extend({ return L.isObject(list[0]) ? list : [ list ]; }, - _rrdtool: function(def, rrd, timespan, width, height) { + _rrdtool: function(def, rrd, timespan, width, height, cache) { var cmdline = [ 'graph', '-', '-a', 'PNG', '-s', 'NOW-%s'.format(timespan || this.opts.timespan), @@ -322,6 +347,15 @@ return L.Class.extend({ cmdline.push(opt); } + if (L.isObject(cache)) { + var key = sfh(cmdline.join('\0')); + + if (!cache.hasOwnProperty(key)) + cache[key] = fs.exec_direct('/usr/bin/rrdtool', cmdline, 'blob', true); + + return cache[key]; + } + return fs.exec_direct('/usr/bin/rrdtool', cmdline, 'blob', true); }, @@ -682,7 +716,7 @@ return L.Class.extend({ return defs; }, - render: function(plugin, plugin_instance, is_index, hostname, timespan, width, height) { + render: function(plugin, plugin_instance, is_index, hostname, timespan, width, height, cache) { var pngs = []; /* check for a whole graph handler */ @@ -705,7 +739,7 @@ return L.Class.extend({ /* render all diagrams */ for (var j = 0; j < diagrams.length; j++) { /* exec */ - _images[i][j] = this._rrdtool(diagrams[j], null, timespan, width, height); + _images[i][j] = this._rrdtool(diagrams[j], null, timespan, width, height, cache); } } } |