refactor: move timeInfo to DataRequestInfo (#16664)

* use timeInfo from request

* move timeInfo to DataRequestInfo
This commit is contained in:
Ryan McKinley 2019-04-18 00:00:46 -07:00 committed by GitHub
parent 0643dff2f6
commit 5976b421fe
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 11 additions and 13 deletions

View File

@ -223,7 +223,7 @@ export interface ScopedVars {
export interface DataQueryOptions<TQuery extends DataQuery = DataQuery> {
timezone: string;
range: TimeRange;
rangeRaw: RawTimeRange;
rangeRaw: RawTimeRange; // Duplicate of results in range. will be deprecated eventually
targets: TQuery[];
panelId: number;
dashboardId: number;
@ -238,6 +238,7 @@ export interface DataQueryOptions<TQuery extends DataQuery = DataQuery> {
* Timestamps when the query starts and stops
*/
export interface DataRequestInfo extends DataQueryOptions {
timeInfo?: string; // The query time description (blue text in the upper right)
startTime: number;
endTime?: number;
}

View File

@ -17,7 +17,7 @@ import config from 'app/core/config';
// Types
import { DashboardModel, PanelModel } from '../state';
import { PanelPlugin } from 'app/types';
import { TimeRange, LoadingState, PanelData } from '@grafana/ui';
import { LoadingState, PanelData } from '@grafana/ui';
import { ScopedVars } from '@grafana/ui';
import templateSrv from 'app/features/templating/template_srv';
@ -39,8 +39,6 @@ export interface Props {
export interface State {
isFirstLoad: boolean;
renderCounter: number;
timeInfo?: string;
timeRange?: TimeRange;
errorMessage: string | null;
// Current state of all events
@ -133,11 +131,6 @@ export class PanelChrome extends PureComponent<Props, State> {
const { panel, width } = this.props;
const timeData = applyPanelTimeOverrides(panel, this.timeSrv.timeRange());
this.setState({
timeRange: timeData.timeRange,
timeInfo: timeData.timeInfo,
});
// Issue Query
if (this.wantsQueryExecution) {
if (width < 0) {
@ -157,6 +150,7 @@ export class PanelChrome extends PureComponent<Props, State> {
dashboardId: this.props.dashboard.id,
timezone: this.props.dashboard.timezone,
timeRange: timeData.timeRange,
timeInfo: timeData.timeInfo,
widthPixels: width,
minInterval: undefined, // Currently not passed in DataPanel?
maxDataPoints: panel.maxDataPoints,
@ -201,7 +195,7 @@ export class PanelChrome extends PureComponent<Props, State> {
renderPanel(width: number, height: number): JSX.Element {
const { panel, plugin } = this.props;
const { timeRange, renderCounter, data, isFirstLoad } = this.state;
const { renderCounter, data, isFirstLoad } = this.state;
const PanelComponent = plugin.reactPlugin.panel;
// This is only done to increase a counter that is used by backend
@ -222,7 +216,7 @@ export class PanelChrome extends PureComponent<Props, State> {
<div className="panel-content">
<PanelComponent
data={data}
timeRange={timeRange}
timeRange={data.request ? data.request.range : this.timeSrv.timeRange()}
options={panel.getOptions(plugin.reactPlugin.defaults)}
width={width - 2 * config.theme.panelPadding.horizontal}
height={height - PANEL_HEADER_HEIGHT - config.theme.panelPadding.vertical}
@ -244,7 +238,7 @@ export class PanelChrome extends PureComponent<Props, State> {
render() {
const { dashboard, panel, isFullscreen, width, height } = this.props;
const { errorMessage, timeInfo } = this.state;
const { errorMessage, data } = this.state;
const { transparent } = panel;
const containerClassNames = `panel-container panel-container--absolute ${transparent ? 'panel-transparent' : ''}`;
@ -253,7 +247,7 @@ export class PanelChrome extends PureComponent<Props, State> {
<PanelHeader
panel={panel}
dashboard={dashboard}
timeInfo={timeInfo}
timeInfo={data.request ? data.request.timeInfo : null}
title={panel.title}
description={panel.description}
scopedVars={panel.scopedVars}

View File

@ -28,6 +28,7 @@ export interface QueryRunnerOptions<TQuery extends DataQuery = DataQuery> {
dashboardId?: number;
timezone?: string;
timeRange?: TimeRange;
timeInfo?: string; // String description of time range for display
widthPixels: number;
minInterval?: string;
maxDataPoints?: number;
@ -92,6 +93,7 @@ export class PanelQueryRunner {
panelId,
dashboardId,
timeRange,
timeInfo,
cacheTimeout,
widthPixels,
maxDataPoints,
@ -105,6 +107,7 @@ export class PanelQueryRunner {
dashboardId,
range: timeRange,
rangeRaw: timeRange.raw,
timeInfo,
interval: '',
intervalMs: 0,
targets: cloneDeep(queries),