grafana/public/app/plugins/datasource/stackdriver/components/QueryEditor.tsx

193 lines
5.1 KiB
TypeScript
Raw Normal View History

import React from 'react';
import _ from 'lodash';
2018-12-19 21:29:00 +08:00
import { Metrics } from './Metrics';
import { Filter } from './Filter';
2018-12-19 21:29:00 +08:00
import { Aggregations } from './Aggregations';
2018-12-20 00:12:50 +08:00
import { Alignments } from './Alignments';
2018-12-20 20:36:10 +08:00
import { AlignmentPeriods } from './AlignmentPeriods';
2018-12-20 22:59:21 +08:00
import { AliasBy } from './AliasBy';
2018-12-19 22:54:45 +08:00
import { Target } from '../types';
import { getAlignmentPickerData } from '../functions';
export interface Props {
2018-12-19 21:19:27 +08:00
onQueryChange: (target: Target) => void;
onExecuteQuery?: () => void;
target: Target;
datasource: any;
templateSrv: any;
uiSegmentSrv: any;
}
interface State extends Target {
alignOptions: any[];
}
const DefaultTarget: State = {
defaultProject: 'loading project...',
metricType: '',
2018-12-19 21:19:27 +08:00
metricKind: '',
valueType: '',
refId: '',
service: '',
unit: '',
2018-12-20 18:00:16 +08:00
crossSeriesReducer: 'REDUCE_MEAN',
alignmentPeriod: 'stackdriver-auto',
perSeriesAligner: 'ALIGN_MEAN',
groupBys: [],
filters: [],
aliasBy: '',
alignOptions: [],
};
export class QueryEditor extends React.Component<Props, State> {
state: State = DefaultTarget;
componentDidMount() {
const { perSeriesAligner, alignOptions } = getAlignmentPickerData(this.props.target, this.props.templateSrv);
this.setState({
...this.props.target,
alignOptions,
perSeriesAligner,
});
}
handleMetricTypeChange({ valueType, metricKind, type, unit }) {
const { perSeriesAligner, alignOptions } = getAlignmentPickerData(
{ valueType, metricKind, perSeriesAligner: this.state.perSeriesAligner },
this.props.templateSrv
);
2018-12-19 22:54:45 +08:00
this.setState(
{
alignOptions,
perSeriesAligner,
2018-12-20 18:00:16 +08:00
metricType: type,
unit,
valueType,
metricKind,
},
2018-12-19 22:54:45 +08:00
() => {
2018-12-20 20:27:47 +08:00
this.props.onQueryChange(this.state);
2018-12-19 22:54:45 +08:00
this.props.onExecuteQuery();
}
);
}
2018-12-19 21:19:27 +08:00
handleFilterChange(value) {
2018-12-19 22:54:45 +08:00
this.setState(
{
2018-12-20 18:00:16 +08:00
filters: value,
2018-12-19 21:19:27 +08:00
},
2018-12-19 22:54:45 +08:00
() => {
2018-12-20 20:27:47 +08:00
this.props.onQueryChange(this.state);
2018-12-19 22:54:45 +08:00
this.props.onExecuteQuery();
}
);
2018-12-19 21:19:27 +08:00
}
handleGroupBysChange(value) {
2018-12-19 22:54:45 +08:00
this.setState(
{
2018-12-20 18:00:16 +08:00
groupBys: value,
2018-12-19 21:19:27 +08:00
},
2018-12-19 22:54:45 +08:00
() => {
2018-12-20 20:27:47 +08:00
this.props.onQueryChange(this.state);
2018-12-19 22:54:45 +08:00
this.props.onExecuteQuery();
}
);
2018-12-19 21:19:27 +08:00
}
handleAggregationChange(value) {
2018-12-20 18:00:16 +08:00
this.setState({ crossSeriesReducer: value }, () => {
2018-12-20 20:27:47 +08:00
this.props.onQueryChange(this.state);
2018-12-19 22:54:45 +08:00
this.props.onExecuteQuery();
2018-12-19 21:19:27 +08:00
});
}
2018-12-20 00:12:50 +08:00
handleAlignmentChange(value) {
2018-12-20 18:00:16 +08:00
this.setState({ perSeriesAligner: value }, () => {
2018-12-20 20:27:47 +08:00
this.props.onQueryChange(this.state);
2018-12-20 00:12:50 +08:00
this.props.onExecuteQuery();
});
}
2018-12-20 20:36:10 +08:00
handleAlignmentPeriodChange(value) {
this.setState({ alignmentPeriod: value }, () => {
this.props.onQueryChange(this.state);
this.props.onExecuteQuery();
});
}
2018-12-20 18:00:16 +08:00
2018-12-20 22:59:21 +08:00
handleAliasByChange(value) {
this.setState({ aliasBy: value }, () => {
this.props.onQueryChange(this.state);
this.props.onExecuteQuery();
});
}
render() {
2018-12-20 20:36:10 +08:00
const {
defaultProject,
metricType,
crossSeriesReducer,
groupBys,
perSeriesAligner,
alignOptions,
alignmentPeriod,
2018-12-20 22:59:21 +08:00
aliasBy,
2018-12-20 20:36:10 +08:00
} = this.state;
const { templateSrv, datasource, uiSegmentSrv } = this.props;
return (
<React.Fragment>
2018-12-19 21:29:00 +08:00
<Metrics
defaultProject={defaultProject}
metricType={metricType}
templateSrv={templateSrv}
datasource={datasource}
onChange={value => this.handleMetricTypeChange(value)}
2018-12-19 22:54:45 +08:00
>
{metric => (
<React.Fragment>
<Filter
filtersChanged={value => this.handleFilterChange(value)}
groupBysChanged={value => this.handleGroupBysChange(value)}
2018-12-20 18:00:16 +08:00
target={this.state}
2018-12-19 22:54:45 +08:00
uiSegmentSrv={uiSegmentSrv}
templateSrv={templateSrv}
datasource={datasource}
metricType={metric ? metric.type : ''}
/>
<Aggregations
metricDescriptor={metric}
templateSrv={templateSrv}
2018-12-20 18:00:16 +08:00
crossSeriesReducer={crossSeriesReducer}
groupBys={groupBys}
2018-12-19 22:54:45 +08:00
onChange={value => this.handleAggregationChange(value)}
2018-12-19 23:08:18 +08:00
>
{displayAdvancedOptions =>
displayAdvancedOptions && (
<Alignments
alignOptions={alignOptions}
metricDescriptor={metric}
templateSrv={templateSrv}
perSeriesAligner={perSeriesAligner}
onChange={value => this.handleAlignmentChange(value)}
/>
)
}
2018-12-19 23:08:18 +08:00
</Aggregations>
2018-12-20 20:36:10 +08:00
<AlignmentPeriods
templateSrv={templateSrv}
alignmentPeriod={alignmentPeriod}
onChange={value => this.handleAlignmentPeriodChange(value)}
/>
2018-12-20 22:59:21 +08:00
<AliasBy value={aliasBy} onChange={value => this.handleAliasByChange(value)} />
2018-12-19 22:54:45 +08:00
</React.Fragment>
)}
</Metrics>
</React.Fragment>
);
}
}