| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 |
- define([
- 'lodash',
- 'app/core/table_model',
- ],
- function (_, TableModel) {
- 'use strict';
- function InfluxSeries(options) {
- this.series = options.series;
- this.alias = options.alias;
- this.annotation = options.annotation;
- }
- var p = InfluxSeries.prototype;
- p.getTimeSeries = function() {
- var output = [];
- var self = this;
- var i, j;
- if (self.series.length === 0) {
- return output;
- }
- _.each(self.series, function(series) {
- var columns = series.columns.length;
- var tags = _.map(series.tags, function(value, key) {
- return key + ': ' + value;
- });
- for (j = 1; j < columns; j++) {
- var seriesName = series.name;
- var columnName = series.columns[j];
- if (columnName !== 'value') {
- seriesName = seriesName + '.' + columnName;
- }
- if (self.alias) {
- seriesName = self._getSeriesName(series, j);
- } else if (series.tags) {
- seriesName = seriesName + ' {' + tags.join(', ') + '}';
- }
- var datapoints = [];
- if (series.values) {
- for (i = 0; i < series.values.length; i++) {
- datapoints[i] = [series.values[i][j], series.values[i][0]];
- }
- }
- output.push({ target: seriesName, datapoints: datapoints});
- }
- });
- return output;
- };
- p._getSeriesName = function(series, index) {
- var regex = /\$(\w+)|\[\[([\s\S]+?)\]\]/g;
- var segments = series.name.split('.');
- return this.alias.replace(regex, function(match, g1, g2) {
- var group = g1 || g2;
- var segIndex = parseInt(group, 10);
- if (group === 'm' || group === 'measurement') { return series.name; }
- if (group === 'col') { return series.columns[index]; }
- if (!isNaN(segIndex)) { return segments[segIndex]; }
- if (group.indexOf('tag_') !== 0) { return match; }
- var tag = group.replace('tag_', '');
- if (!series.tags) { return match; }
- return series.tags[tag];
- });
- };
- p.getAnnotations = function () {
- var list = [];
- var self = this;
- _.each(this.series, function (series) {
- var titleCol = null;
- var timeCol = null;
- var tagsCol = null;
- var textCol = null;
- _.each(series.columns, function(column, index) {
- if (column === 'time') { timeCol = index; return; }
- if (column === 'sequence_number') { return; }
- if (!titleCol) { titleCol = index; }
- if (column === self.annotation.titleColumn) { titleCol = index; return; }
- if (column === self.annotation.tagsColumn) { tagsCol = index; return; }
- if (column === self.annotation.textColumn) { textCol = index; return; }
- });
- _.each(series.values, function (value) {
- var data = {
- annotation: self.annotation,
- time: + new Date(value[timeCol]),
- title: value[titleCol],
- tags: value[tagsCol],
- text: value[textCol]
- };
- list.push(data);
- });
- });
- return list;
- };
- p.getTable = function() {
- var table = new TableModel.default();
- var self = this;
- var i, j;
- if (self.series.length === 0) {
- return table;
- }
- _.each(self.series, function(series, seriesIndex) {
- if (seriesIndex === 0) {
- table.columns.push({text: 'Time', type: 'time'});
- _.each(_.keys(series.tags), function(key) {
- table.columns.push({text: key});
- });
- for (j = 1; j < series.columns.length; j++) {
- table.columns.push({text: series.columns[j]});
- }
- }
- if (series.values) {
- for (i = 0; i < series.values.length; i++) {
- var values = series.values[i];
- var reordered = [values[0]];
- if (series.tags) {
- for (var key in series.tags) {
- if (series.tags.hasOwnProperty(key)) {
- reordered.push(series.tags[key]);
- }
- }
- }
- for (j = 1; j < values.length; j++) {
- reordered.push(values[j]);
- }
- table.rows.push(reordered);
- }
- }
- });
- return table;
- };
- return InfluxSeries;
- });
|