influxSeries.js 3.5 KB

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