influxSeries.js 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  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.annotation = options.annotation;
  10. }
  11. var p = InfluxSeries.prototype;
  12. p.getTimeSeries = function() {
  13. var output = [];
  14. var self = this;
  15. console.log(self.seriesList);
  16. if (!self.seriesList || !self.seriesList.results || !self.seriesList.results[0]) {
  17. return output;
  18. }
  19. this.seriesList = self.seriesList.results[0].series;
  20. _.each(self.seriesList, function(series) {
  21. var datapoints = [];
  22. for (var i = 0; i < series.values.length; i++) {
  23. datapoints[i] = [series.values[i][1], new Date(series.values[i][0]).getTime()];
  24. }
  25. var seriesName = series.name;
  26. var tags = _.map(series.tags, function(value, key) {
  27. return key + ': ' + value;
  28. });
  29. if (tags.length > 0) {
  30. seriesName = seriesName + ' {' + tags.join(', ') + '}';
  31. }
  32. output.push({ target: seriesName, datapoints: datapoints });
  33. });
  34. return output;
  35. };
  36. p.getAnnotations = function () {
  37. var list = [];
  38. var self = this;
  39. _.each(this.seriesList, function (series) {
  40. var titleCol = null;
  41. var timeCol = null;
  42. var tagsCol = null;
  43. var textCol = null;
  44. _.each(series.columns, function(column, index) {
  45. if (column === 'time') { timeCol = index; return; }
  46. if (column === 'sequence_number') { return; }
  47. if (!titleCol) { titleCol = index; }
  48. if (column === self.annotation.titleColumn) { titleCol = index; return; }
  49. if (column === self.annotation.tagsColumn) { tagsCol = index; return; }
  50. if (column === self.annotation.textColumn) { textCol = index; return; }
  51. });
  52. _.each(series.points, function (point) {
  53. var data = {
  54. annotation: self.annotation,
  55. time: point[timeCol],
  56. title: point[titleCol],
  57. tags: point[tagsCol],
  58. text: point[textCol]
  59. };
  60. if (tagsCol) {
  61. data.tags = point[tagsCol];
  62. }
  63. list.push(data);
  64. });
  65. });
  66. return list;
  67. };
  68. p.createNameForSeries = function(seriesName, groupByColValue) {
  69. var regex = /\$(\w+)/g;
  70. var segments = seriesName.split('.');
  71. return this.alias.replace(regex, function(match, group) {
  72. if (group === 's') {
  73. return seriesName;
  74. }
  75. else if (group === 'g') {
  76. return groupByColValue;
  77. }
  78. var index = parseInt(group);
  79. if (_.isNumber(index) && index < segments.length) {
  80. return segments[index];
  81. }
  82. return match;
  83. });
  84. };
  85. return InfluxSeries;
  86. });