1234567891011121314151617181920212223242526272829303132333435363738394041 |
- import { css, cx } from '@emotion/css';
- import React from 'react';
- 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 = ({ options, onChange, className, value }: Props) => {
- const selectedOption = options.find((option) => option.id === value);
- return (
- <Segment
- className={cx(className, noWrap)}
- options={toOptions(options)}
- onChange={onChange}
- placeholder="Select Metric"
- value={!!selectedOption ? toOption(selectedOption) : undefined}
- />
- );
- };
|