legend.js 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. define([
  2. 'angular',
  3. 'app',
  4. 'lodash',
  5. 'kbn',
  6. 'jquery',
  7. 'jquery.flot',
  8. 'jquery.flot.time',
  9. ],
  10. function (angular, app, _, kbn, $) {
  11. 'use strict';
  12. var module = angular.module('grafana.panels.graph');
  13. module.directive('graphLegend', function(popoverSrv) {
  14. return {
  15. link: function(scope, elem) {
  16. var $container = $('<section class="graph-legend"></section>');
  17. var firstRender = true;
  18. var panel = scope.panel;
  19. var data;
  20. var seriesList;
  21. var i;
  22. scope.$on('render', function() {
  23. data = scope.seriesList;
  24. if (data) {
  25. render();
  26. }
  27. });
  28. function getSeriesIndexForElement(el) {
  29. return el.parents('[data-series-index]').data('series-index');
  30. }
  31. function openColorSelector(e) {
  32. var el = $(e.currentTarget);
  33. var index = getSeriesIndexForElement(el);
  34. var seriesInfo = seriesList[index];
  35. var popoverScope = scope.$new();
  36. popoverScope.series = seriesInfo;
  37. popoverSrv.show({
  38. element: el,
  39. templateUrl: 'app/panels/graph/legend.popover.html',
  40. scope: popoverScope
  41. });
  42. }
  43. function toggleSeries(e) {
  44. var el = $(e.currentTarget);
  45. var index = getSeriesIndexForElement(el);
  46. var seriesInfo = seriesList[index];
  47. scope.toggleSeries(seriesInfo, e);
  48. }
  49. function sortLegend(e) {
  50. var el = $(e.currentTarget);
  51. var stat = el.data('stat');
  52. if (stat !== panel.legend.sort) { panel.legend.sortDesc = null; }
  53. // if already sort ascending, disable sorting
  54. if (panel.legend.sortDesc === false) {
  55. panel.legend.sort = null;
  56. panel.legend.sortDesc = null;
  57. render();
  58. return;
  59. }
  60. panel.legend.sortDesc = !panel.legend.sortDesc;
  61. panel.legend.sort = stat;
  62. render();
  63. }
  64. function getTableHeaderHtml(statName) {
  65. if (!panel.legend[statName]) { return ""; }
  66. var html = '<th class="pointer" data-stat="' + statName + '">' + statName;
  67. if (panel.legend.sort === statName) {
  68. var cssClass = panel.legend.sortDesc ? 'fa fa-caret-down' : 'fa fa-caret-up' ;
  69. html += ' <span class="' + cssClass + '"></span>';
  70. }
  71. return html + '</th>';
  72. }
  73. function render() {
  74. if (firstRender) {
  75. elem.append($container);
  76. $container.on('click', '.graph-legend-icon', openColorSelector);
  77. $container.on('click', '.graph-legend-alias', toggleSeries);
  78. $container.on('click', 'th', sortLegend);
  79. firstRender = false;
  80. }
  81. seriesList = data;
  82. $container.empty();
  83. $container.toggleClass('graph-legend-table', panel.legend.alignAsTable === true);
  84. if (panel.legend.alignAsTable) {
  85. var header = '<tr>';
  86. header += '<th colspan="2" style="text-align:left"></th>';
  87. if (panel.legend.values) {
  88. header += getTableHeaderHtml('min');
  89. header += getTableHeaderHtml('max');
  90. header += getTableHeaderHtml('avg');
  91. header += getTableHeaderHtml('current');
  92. header += getTableHeaderHtml('total');
  93. }
  94. header += '</tr>';
  95. $container.append($(header));
  96. }
  97. if (panel.legend.sort) {
  98. seriesList = _.sortBy(seriesList, function(series) {
  99. return series.stats[panel.legend.sort];
  100. });
  101. if (panel.legend.sortDesc) {
  102. seriesList = seriesList.reverse();
  103. }
  104. }
  105. for (i = 0; i < seriesList.length; i++) {
  106. var series = seriesList[i];
  107. // ignore empty series
  108. if (panel.legend.hideEmpty && series.allIsNull) {
  109. continue;
  110. }
  111. var html = '<div class="graph-legend-series';
  112. if (series.yaxis === 2) { html += ' pull-right'; }
  113. if (scope.hiddenSeries[series.alias]) { html += ' graph-legend-series-hidden'; }
  114. html += '" data-series-index="' + i + '">';
  115. html += '<div class="graph-legend-icon">';
  116. html += '<i class="fa fa-minus pointer" style="color:' + series.color + '"></i>';
  117. html += '</div>';
  118. html += '<div class="graph-legend-alias">';
  119. html += '<a>' + series.label + '</a>';
  120. html += '</div>';
  121. if (panel.legend.values) {
  122. var avg = series.formatValue(series.stats.avg);
  123. var current = series.formatValue(series.stats.current);
  124. var min = series.formatValue(series.stats.min);
  125. var max = series.formatValue(series.stats.max);
  126. var total = series.formatValue(series.stats.total);
  127. if (panel.legend.min) { html += '<div class="graph-legend-value min">' + min + '</div>'; }
  128. if (panel.legend.max) { html += '<div class="graph-legend-value max">' + max + '</div>'; }
  129. if (panel.legend.avg) { html += '<div class="graph-legend-value avg">' + avg + '</div>'; }
  130. if (panel.legend.current) { html += '<div class="graph-legend-value current">' + current + '</div>'; }
  131. if (panel.legend.total) { html += '<div class="graph-legend-value total">' + total + '</div>'; }
  132. }
  133. html += '</div>';
  134. $container.append($(html));
  135. }
  136. }
  137. }
  138. };
  139. });
  140. });