mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
GraphPanel: use SeriesData directly (skip legacy transformation) (#17037)
* support streaming in angular panels * keep the same dashboard number * skip the legacy data conversion * fix tests
This commit is contained in:
committed by
Torkel Ödegaard
parent
7333f7ca17
commit
a0b6ef4d01
@@ -15,6 +15,7 @@ import {
|
||||
PanelData,
|
||||
LoadingState,
|
||||
DataQueryResponse,
|
||||
SeriesData,
|
||||
} from '@grafana/ui';
|
||||
import { Unsubscribable } from 'rxjs';
|
||||
import { PanelModel } from 'app/features/dashboard/state';
|
||||
@@ -37,6 +38,7 @@ class MetricsPanelCtrl extends PanelCtrl {
|
||||
skipDataOnInit: boolean;
|
||||
dataList: LegacyResponseData[];
|
||||
querySubscription?: Unsubscribable;
|
||||
dataFormat = PanelQueryRunnerFormat.legacy;
|
||||
|
||||
constructor($scope: any, $injector: any) {
|
||||
super($scope, $injector);
|
||||
@@ -134,16 +136,6 @@ class MetricsPanelCtrl extends PanelCtrl {
|
||||
|
||||
this.loading = false;
|
||||
|
||||
// The result should already be processed, but just in case
|
||||
if (!data.legacy) {
|
||||
data.legacy = data.series.map(v => {
|
||||
if (isSeriesData(v)) {
|
||||
return toLegacyResponseData(v);
|
||||
}
|
||||
return v;
|
||||
});
|
||||
}
|
||||
|
||||
if (data.request) {
|
||||
const { range, timeInfo } = data.request;
|
||||
if (range) {
|
||||
@@ -154,11 +146,25 @@ class MetricsPanelCtrl extends PanelCtrl {
|
||||
}
|
||||
}
|
||||
|
||||
// Make the results look like they came directly from a <6.2 datasource request
|
||||
// NOTE: any object other than 'data' is no longer supported supported
|
||||
this.handleQueryResult({
|
||||
data: data.legacy,
|
||||
});
|
||||
if (this.dataFormat === PanelQueryRunnerFormat.legacy) {
|
||||
// The result should already be processed, but just in case
|
||||
if (!data.legacy) {
|
||||
data.legacy = data.series.map(v => {
|
||||
if (isSeriesData(v)) {
|
||||
return toLegacyResponseData(v);
|
||||
}
|
||||
return v;
|
||||
});
|
||||
}
|
||||
|
||||
// Make the results look like they came directly from a <6.2 datasource request
|
||||
// NOTE: any object other than 'data' is no longer supported supported
|
||||
this.handleQueryResult({
|
||||
data: data.legacy,
|
||||
});
|
||||
} else {
|
||||
this.handleSeriesData(data.series);
|
||||
}
|
||||
},
|
||||
};
|
||||
|
||||
@@ -198,7 +204,7 @@ class MetricsPanelCtrl extends PanelCtrl {
|
||||
const queryRunner = panel.getQueryRunner();
|
||||
|
||||
if (!this.querySubscription) {
|
||||
this.querySubscription = queryRunner.subscribe(this.panelDataObserver, PanelQueryRunnerFormat.legacy);
|
||||
this.querySubscription = queryRunner.subscribe(this.panelDataObserver, this.dataFormat);
|
||||
}
|
||||
|
||||
return queryRunner.run({
|
||||
@@ -216,6 +222,16 @@ class MetricsPanelCtrl extends PanelCtrl {
|
||||
});
|
||||
}
|
||||
|
||||
handleSeriesData(data: SeriesData[]) {
|
||||
this.loading = false;
|
||||
|
||||
if (this.dashboard && this.dashboard.snapshot) {
|
||||
this.panel.snapshotData = data;
|
||||
}
|
||||
|
||||
// Subclasses that asked for SeriesData will override
|
||||
}
|
||||
|
||||
handleQueryResult(result: DataQueryResponse) {
|
||||
this.loading = false;
|
||||
|
||||
|
@@ -13,6 +13,7 @@ import config from 'app/core/config';
|
||||
import TimeSeries from 'app/core/time_series2';
|
||||
import { getColorFromHexRgbOrName, LegacyResponseData, SeriesData } from '@grafana/ui';
|
||||
import { getProcessedSeriesData } from 'app/features/dashboard/state/PanelQueryState';
|
||||
import { PanelQueryRunnerFormat } from 'app/features/dashboard/state/PanelQueryRunner';
|
||||
|
||||
class GraphCtrl extends MetricsPanelCtrl {
|
||||
static template = template;
|
||||
@@ -128,6 +129,7 @@ class GraphCtrl extends MetricsPanelCtrl {
|
||||
_.defaults(this.panel.legend, this.panelDefaults.legend);
|
||||
_.defaults(this.panel.xaxis, this.panelDefaults.xaxis);
|
||||
|
||||
this.dataFormat = PanelQueryRunnerFormat.series;
|
||||
this.processor = new DataProcessor(this.panel);
|
||||
|
||||
this.events.on('render', this.onRender.bind(this));
|
||||
@@ -188,8 +190,16 @@ class GraphCtrl extends MetricsPanelCtrl {
|
||||
this.render([]);
|
||||
}
|
||||
|
||||
// This should only be called from the snapshot callback
|
||||
onDataReceived(dataList: LegacyResponseData[]) {
|
||||
this.dataList = getProcessedSeriesData(dataList);
|
||||
this.handleSeriesData(getProcessedSeriesData(dataList));
|
||||
}
|
||||
|
||||
// Directly support SeriesData skipping event callbacks
|
||||
handleSeriesData(data: SeriesData[]) {
|
||||
super.handleSeriesData(data);
|
||||
|
||||
this.dataList = data;
|
||||
this.seriesList = this.processor.getSeriesList({
|
||||
dataList: this.dataList,
|
||||
range: this.range,
|
||||
|
Reference in New Issue
Block a user