Files
grafana/public/app/plugins/datasource/elasticsearch/components/MetricPicker.tsx
Giordano Ricci bb45f5fedc Elasticsearch: Migrate queryeditor to React (#28033)
Co-authored-by: Zoltán Bedi <zoltan.bedi@gmail.com>
Co-authored-by: Torkel Ödegaard <torkel@grafana.com>
2020-12-04 14:29:40 +00:00

35 lines
1.0 KiB
TypeScript

import React, { FunctionComponent } from 'react';
import { css, cx } from 'emotion';
import { SelectableValue } from '@grafana/data';
import { Segment } from '@grafana/ui';
import { describeMetric } from '../utils';
import { MetricAggregation } from './QueryEditor/MetricAggregationsEditor/aggregations';
const noWrap = css`
white-space: nowrap;
`;
const toOption = (metric: MetricAggregation) => ({
label: describeMetric(metric),
value: metric,
});
const toOptions = (metrics: MetricAggregation[]): Array<SelectableValue<MetricAggregation>> => metrics.map(toOption);
interface Props {
options: MetricAggregation[];
onChange: (e: SelectableValue<MetricAggregation>) => void;
className?: string;
value?: string;
}
export const MetricPicker: FunctionComponent<Props> = ({ options, onChange, className, value }) => (
<Segment
className={cx(className, noWrap)}
options={toOptions(options)}
onChange={onChange}
placeholder="Select Metric"
value={!!value ? toOption(options.find(option => option.id === value)!) : null}
/>
);