influx_series.js 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. define([
  2. 'lodash',
  3. 'app/core/table_model',
  4. ],
  5. function (_, TableModel) {
  6. 'use strict';
  7. function InfluxSeries(options) {
  8. this.series = options.series;
  9. this.alias = options.alias;
  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, j;
  17. if (self.series.length === 0) {
  18. return output;
  19. }
  20. _.each(self.series, function(series) {
  21. var columns = series.columns.length;
  22. var tags = _.map(series.tags, function(value, key) {
  23. return key + ': ' + value;
  24. });
  25. for (j = 1; j < columns; j++) {
  26. var seriesName = series.name;
  27. var columnName = series.columns[j];
  28. if (columnName !== 'value') {
  29. seriesName = seriesName + '.' + columnName;
  30. }
  31. if (self.alias) {
  32. seriesName = self._getSeriesName(series, j);
  33. } else if (series.tags) {
  34. seriesName = seriesName + ' {' + tags.join(', ') + '}';
  35. }
  36. var datapoints = [];
  37. if (series.values) {
  38. for (i = 0; i < series.values.length; i++) {
  39. datapoints[i] = [series.values[i][j], series.values[i][0]];
  40. }
  41. }
  42. output.push({ target: seriesName, datapoints: datapoints});
  43. }
  44. });
  45. return output;
  46. };
  47. p._getSeriesName = function(series, index) {
  48. var regex = /\$(\w+)|\[\[([\s\S]+?)\]\]/g;
  49. var segments = series.name.split('.');
  50. return this.alias.replace(regex, function(match, g1, g2) {
  51. var group = g1 || g2;
  52. var segIndex = parseInt(group, 10);
  53. if (group === 'm' || group === 'measurement') { return series.name; }
  54. if (group === 'col') { return series.columns[index]; }
  55. if (!isNaN(segIndex)) { return segments[segIndex]; }
  56. if (group.indexOf('tag_') !== 0) { return match; }
  57. var tag = group.replace('tag_', '');
  58. if (!series.tags) { return match; }
  59. return series.tags[tag];
  60. });
  61. };
  62. p.getAnnotations = function () {
  63. var list = [];
  64. var self = this;
  65. _.each(this.series, function (series) {
  66. var titleCol = null;
  67. var timeCol = null;
  68. var tagsCol = null;
  69. var textCol = null;
  70. _.each(series.columns, function(column, index) {
  71. if (column === 'time') { timeCol = index; return; }
  72. if (column === 'sequence_number') { return; }
  73. if (!titleCol) { titleCol = index; }
  74. if (column === self.annotation.titleColumn) { titleCol = index; return; }
  75. if (column === self.annotation.tagsColumn) { tagsCol = index; return; }
  76. if (column === self.annotation.textColumn) { textCol = index; return; }
  77. });
  78. _.each(series.values, function (value) {
  79. var data = {
  80. annotation: self.annotation,
  81. time: + new Date(value[timeCol]),
  82. title: value[titleCol],
  83. tags: value[tagsCol],
  84. text: value[textCol]
  85. };
  86. list.push(data);
  87. });
  88. });
  89. return list;
  90. };
  91. p.getTable = function() {
  92. var table = new TableModel.default();
  93. var self = this;
  94. var i, j;
  95. if (self.series.length === 0) {
  96. return table;
  97. }
  98. _.each(self.series, function(series, seriesIndex) {
  99. if (seriesIndex === 0) {
  100. table.columns.push({text: 'Time', type: 'time'});
  101. _.each(_.keys(series.tags), function(key) {
  102. table.columns.push({text: key});
  103. });
  104. for (j = 1; j < series.columns.length; j++) {
  105. table.columns.push({text: series.columns[j]});
  106. }
  107. }
  108. if (series.values) {
  109. for (i = 0; i < series.values.length; i++) {
  110. var values = series.values[i];
  111. var reordered = [values[0]];
  112. if (series.tags) {
  113. for (var key in series.tags) {
  114. if (series.tags.hasOwnProperty(key)) {
  115. reordered.push(series.tags[key]);
  116. }
  117. }
  118. }
  119. for (j = 1; j < values.length; j++) {
  120. reordered.push(values[j]);
  121. }
  122. table.rows.push(reordered);
  123. }
  124. }
  125. });
  126. return table;
  127. };
  128. return InfluxSeries;
  129. });