mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
add alignment periods component
This commit is contained in:
parent
7a31076f09
commit
861f911cda
@ -0,0 +1,36 @@
|
|||||||
|
import React, { SFC } from 'react';
|
||||||
|
import _ from 'lodash';
|
||||||
|
|
||||||
|
import { StackdriverPicker } from './StackdriverPicker';
|
||||||
|
import { alignmentPeriods } from '../constants';
|
||||||
|
|
||||||
|
export interface Props {
|
||||||
|
onChange: (alignmentPeriod) => void;
|
||||||
|
templateSrv: any;
|
||||||
|
alignmentPeriod: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export const AlignmentPeriods: SFC<Props> = ({ alignmentPeriod, templateSrv, onChange }) => {
|
||||||
|
return (
|
||||||
|
<React.Fragment>
|
||||||
|
<div className="gf-form-inline">
|
||||||
|
<div className="gf-form">
|
||||||
|
<label className="gf-form-label query-keyword width-9">Alignment Period</label>
|
||||||
|
<StackdriverPicker
|
||||||
|
onChange={value => onChange(value)}
|
||||||
|
selected={alignmentPeriod}
|
||||||
|
templateVariables={templateSrv.variables}
|
||||||
|
options={alignmentPeriods.map(ap => ({
|
||||||
|
...ap,
|
||||||
|
label: ap.text,
|
||||||
|
}))}
|
||||||
|
searchable={true}
|
||||||
|
placeholder="Select Alignment"
|
||||||
|
className="width-15"
|
||||||
|
groupName="Alignment Options"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</React.Fragment>
|
||||||
|
);
|
||||||
|
};
|
@ -5,6 +5,7 @@ import { Metrics } from './Metrics';
|
|||||||
import { Filter } from './Filter';
|
import { Filter } from './Filter';
|
||||||
import { Aggregations } from './Aggregations';
|
import { Aggregations } from './Aggregations';
|
||||||
import { Alignments } from './Alignments';
|
import { Alignments } from './Alignments';
|
||||||
|
import { AlignmentPeriods } from './AlignmentPeriods';
|
||||||
import { Target } from '../types';
|
import { Target } from '../types';
|
||||||
import { getAlignmentPickerData } from '../functions';
|
import { getAlignmentPickerData } from '../functions';
|
||||||
|
|
||||||
@ -109,13 +110,23 @@ export class QueryEditor extends React.Component<Props, State> {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// componentDidUpdate(prevProps: Props, prevState: Target) {
|
handleAlignmentPeriodChange(value) {
|
||||||
// this.props.onQueryChange(this.state);
|
this.setState({ alignmentPeriod: value }, () => {
|
||||||
|
this.props.onQueryChange(this.state);
|
||||||
// }
|
this.props.onExecuteQuery();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const { defaultProject, metricType, crossSeriesReducer, groupBys, perSeriesAligner, alignOptions } = this.state;
|
const {
|
||||||
|
defaultProject,
|
||||||
|
metricType,
|
||||||
|
crossSeriesReducer,
|
||||||
|
groupBys,
|
||||||
|
perSeriesAligner,
|
||||||
|
alignOptions,
|
||||||
|
alignmentPeriod,
|
||||||
|
} = this.state;
|
||||||
const { templateSrv, datasource, uiSegmentSrv } = this.props;
|
const { templateSrv, datasource, uiSegmentSrv } = this.props;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
@ -157,6 +168,11 @@ export class QueryEditor extends React.Component<Props, State> {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
</Aggregations>
|
</Aggregations>
|
||||||
|
<AlignmentPeriods
|
||||||
|
templateSrv={templateSrv}
|
||||||
|
alignmentPeriod={alignmentPeriod}
|
||||||
|
onChange={value => this.handleAlignmentPeriodChange(value)}
|
||||||
|
/>
|
||||||
</React.Fragment>
|
</React.Fragment>
|
||||||
)}
|
)}
|
||||||
</Metrics>
|
</Metrics>
|
||||||
|
Loading…
Reference in New Issue
Block a user