2018-12-13 23:40:14 +08:00
|
|
|
import React from 'react';
|
|
|
|
import _ from 'lodash';
|
|
|
|
|
2018-12-19 21:29:00 +08:00
|
|
|
import { Metrics } from './Metrics';
|
2018-12-13 23:40:14 +08:00
|
|
|
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-20 23:55:02 +08:00
|
|
|
import { Help } from './Help';
|
2018-12-19 22:54:45 +08:00
|
|
|
import { Target } from '../types';
|
2018-12-20 18:26:05 +08:00
|
|
|
import { getAlignmentPickerData } from '../functions';
|
2018-12-13 23:40:14 +08:00
|
|
|
|
|
|
|
export interface Props {
|
2018-12-19 21:19:27 +08:00
|
|
|
onQueryChange: (target: Target) => void;
|
|
|
|
onExecuteQuery?: () => void;
|
2018-12-13 23:40:14 +08:00
|
|
|
target: Target;
|
2018-12-22 04:38:46 +08:00
|
|
|
events: any;
|
2018-12-13 23:40:14 +08:00
|
|
|
datasource: any;
|
|
|
|
templateSrv: any;
|
|
|
|
uiSegmentSrv: any;
|
|
|
|
}
|
|
|
|
|
2018-12-20 18:26:05 +08:00
|
|
|
interface State extends Target {
|
|
|
|
alignOptions: any[];
|
2018-12-22 04:38:46 +08:00
|
|
|
lastQuery: string;
|
2018-12-20 18:26:05 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
const DefaultTarget: State = {
|
2018-12-13 23:40:14 +08:00
|
|
|
defaultProject: 'loading project...',
|
|
|
|
metricType: '',
|
2018-12-19 21:19:27 +08:00
|
|
|
metricKind: '',
|
|
|
|
valueType: '',
|
2018-12-13 23:40:14 +08:00
|
|
|
refId: '',
|
|
|
|
service: '',
|
|
|
|
unit: '',
|
2018-12-20 18:00:16 +08:00
|
|
|
crossSeriesReducer: 'REDUCE_MEAN',
|
|
|
|
alignmentPeriod: 'stackdriver-auto',
|
|
|
|
perSeriesAligner: 'ALIGN_MEAN',
|
|
|
|
groupBys: [],
|
2018-12-13 23:40:14 +08:00
|
|
|
filters: [],
|
|
|
|
aliasBy: '',
|
2018-12-20 18:26:05 +08:00
|
|
|
alignOptions: [],
|
2018-12-22 04:38:46 +08:00
|
|
|
lastQuery: '',
|
2018-12-13 23:40:14 +08:00
|
|
|
};
|
|
|
|
|
2018-12-20 18:26:05 +08:00
|
|
|
export class QueryEditor extends React.Component<Props, State> {
|
|
|
|
state: State = DefaultTarget;
|
2018-12-13 23:40:14 +08:00
|
|
|
|
|
|
|
componentDidMount() {
|
2018-12-22 04:38:46 +08:00
|
|
|
const { events } = this.props;
|
|
|
|
events.on('data-received', this.onDataReceived.bind(this));
|
|
|
|
events.on('data-error', this.onDataError.bind(this));
|
2018-12-20 18:26:05 +08:00
|
|
|
const { perSeriesAligner, alignOptions } = getAlignmentPickerData(this.props.target, this.props.templateSrv);
|
|
|
|
this.setState({
|
|
|
|
...this.props.target,
|
|
|
|
alignOptions,
|
|
|
|
perSeriesAligner,
|
|
|
|
});
|
2018-12-13 23:40:14 +08:00
|
|
|
}
|
|
|
|
|
2018-12-22 04:38:46 +08:00
|
|
|
onDataReceived(dataList) {
|
|
|
|
const anySeriesFromQuery = dataList.find(item => item.refId === this.props.target.refId);
|
|
|
|
if (anySeriesFromQuery) {
|
|
|
|
this.setState({ lastQuery: decodeURIComponent(anySeriesFromQuery.meta.rawQuery) });
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
onDataError(err) {
|
|
|
|
// if (err.data && err.data.results) {
|
|
|
|
// const queryRes = err.data.results[this.target.refId];
|
|
|
|
// if (queryRes && queryRes.error) {
|
|
|
|
// this.lastQueryMeta = queryRes.meta;
|
|
|
|
// this.lastQueryMeta.rawQueryString = decodeURIComponent(this.lastQueryMeta.rawQuery);
|
|
|
|
// let jsonBody;
|
|
|
|
// try {
|
|
|
|
// jsonBody = JSON.parse(queryRes.error);
|
|
|
|
// } catch {
|
|
|
|
// this.lastQueryError = queryRes.error;
|
|
|
|
// }
|
|
|
|
// this.lastQueryError = jsonBody.error.message;
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
2018-12-13 23:40:14 +08:00
|
|
|
handleMetricTypeChange({ valueType, metricKind, type, unit }) {
|
2018-12-20 18:26:05 +08:00
|
|
|
const { perSeriesAligner, alignOptions } = getAlignmentPickerData(
|
|
|
|
{ valueType, metricKind, perSeriesAligner: this.state.perSeriesAligner },
|
|
|
|
this.props.templateSrv
|
|
|
|
);
|
2018-12-19 22:54:45 +08:00
|
|
|
this.setState(
|
|
|
|
{
|
2018-12-20 18:26:05 +08:00
|
|
|
alignOptions,
|
|
|
|
perSeriesAligner,
|
2018-12-20 18:00:16 +08:00
|
|
|
metricType: type,
|
|
|
|
unit,
|
|
|
|
valueType,
|
|
|
|
metricKind,
|
2018-12-13 23:40:14 +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-13 23:40:14 +08:00
|
|
|
}
|
|
|
|
|
2018-12-20 23:55:02 +08:00
|
|
|
handleFilterChange(filters) {
|
|
|
|
this.setState({ filters }, () => {
|
|
|
|
this.props.onQueryChange(this.state);
|
|
|
|
this.props.onExecuteQuery();
|
|
|
|
});
|
2018-12-19 21:19:27 +08:00
|
|
|
}
|
|
|
|
|
2018-12-20 23:55:02 +08:00
|
|
|
handleGroupBysChange(groupBys) {
|
|
|
|
this.setState({ groupBys }, () => {
|
|
|
|
this.props.onQueryChange(this.state);
|
|
|
|
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-13 23:40:14 +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();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-12-13 23:40:14 +08:00
|
|
|
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-22 04:38:46 +08:00
|
|
|
lastQuery,
|
2018-12-20 20:36:10 +08:00
|
|
|
} = this.state;
|
2018-12-13 23:40:14 +08:00
|
|
|
const { templateSrv, datasource, uiSegmentSrv } = this.props;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<React.Fragment>
|
2018-12-19 21:29:00 +08:00
|
|
|
<Metrics
|
2018-12-13 23:40:14 +08:00
|
|
|
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
|
|
|
>
|
2018-12-20 18:26:05 +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 22:59:21 +08:00
|
|
|
<AliasBy value={aliasBy} onChange={value => this.handleAliasByChange(value)} />
|
2018-12-22 04:38:46 +08:00
|
|
|
|
|
|
|
<AlignmentPeriods
|
|
|
|
templateSrv={templateSrv}
|
|
|
|
alignmentPeriod={alignmentPeriod}
|
|
|
|
onChange={value => this.handleAlignmentPeriodChange(value)}
|
|
|
|
/>
|
|
|
|
|
|
|
|
<Help datasource={datasource} rawQuery={lastQuery} />
|
2018-12-19 22:54:45 +08:00
|
|
|
</React.Fragment>
|
|
|
|
)}
|
|
|
|
</Metrics>
|
2018-12-13 23:40:14 +08:00
|
|
|
</React.Fragment>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|