influxSeries.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. define([
  2. 'lodash',
  3. ],
  4. function (_) {
  5. 'use strict';
  6. function InfluxSeries(options) {
  7. this.seriesList = options.seriesList;
  8. this.alias = options.alias;
  9. this.groupByField = options.groupByField;
  10. this.annotation = options.annotation;
  11. }
  12. var p = InfluxSeries.prototype;
  13. p.getTimeSeries = function() {
  14. var output = [];
  15. var self = this;
  16. var i;
  17. _.each(self.seriesList, function(series) {
  18. var seriesName;
  19. var timeCol = series.columns.indexOf('time');
  20. var valueCol = 1;
  21. var groupByCol = -1;
  22. if (self.groupByField) {
  23. groupByCol = series.columns.indexOf(self.groupByField);
  24. }
  25. // find value column
  26. _.each(series.columns, function(column, index) {
  27. if (column !== 'time' && column !== 'sequence_number' && column !== self.groupByField) {
  28. valueCol = index;
  29. }
  30. });
  31. var groups = {};
  32. if (self.groupByField) {
  33. groups = _.groupBy(series.points, function (point) {
  34. return point[groupByCol];
  35. });
  36. }
  37. else {
  38. groups[series.columns[valueCol]] = series.points;
  39. }
  40. _.each(groups, function(groupPoints, key) {
  41. var datapoints = [];
  42. for (i = 0; i < groupPoints.length; i++) {
  43. var metricValue = isNaN(groupPoints[i][valueCol]) ? null : groupPoints[i][valueCol];
  44. datapoints[i] = [metricValue, groupPoints[i][timeCol]];
  45. }
  46. seriesName = series.name + '.' + key;
  47. if (self.alias) {
  48. seriesName = self.createNameForSeries(series.name, key);
  49. }
  50. output.push({ target: seriesName, datapoints: datapoints });
  51. });
  52. });
  53. return output;
  54. };
  55. p.getAnnotations = function () {
  56. var list = [];
  57. var self = this;
  58. _.each(this.seriesList, function (series) {
  59. var titleCol = null;
  60. var timeCol = null;
  61. var tagsCol = null;
  62. var textCol = null;
  63. _.each(series.columns, function(column, index) {
  64. if (column === 'time') { timeCol = index; return; }
  65. if (column === 'sequence_number') { return; }
  66. if (!titleCol) { titleCol = index; }
  67. if (column === self.annotation.titleColumn) { titleCol = index; return; }
  68. if (column === self.annotation.tagsColumn) { tagsCol = index; return; }
  69. if (column === self.annotation.textColumn) { textCol = index; return; }
  70. });
  71. _.each(series.points, function (point) {
  72. var data = {
  73. annotation: self.annotation,
  74. time: point[timeCol],
  75. title: point[titleCol],
  76. tags: point[tagsCol],
  77. text: point[textCol]
  78. };
  79. if (tagsCol) {
  80. data.tags = point[tagsCol];
  81. }
  82. list.push(data);
  83. });
  84. });
  85. return list;
  86. };
  87. p.createNameForSeries = function(seriesName, groupByColValue) {
  88. var regex = /\$(\w+)/g;
  89. var segments = seriesName.split('.');
  90. return this.alias.replace(regex, function(match, group) {
  91. if (group === 's') {
  92. return seriesName;
  93. }
  94. else if (group === 'g') {
  95. return groupByColValue;
  96. }
  97. var index = parseInt(group);
  98. if (_.isNumber(index) && index < segments.length) {
  99. return segments[index];
  100. }
  101. return match;
  102. });
  103. };
  104. return InfluxSeries;
  105. });