Files
Ashley Harrison 75ff031789 Chore: Fix TypeScript strict errors with components using connect (#37109)
* Chore: Fix TypeScript strict errors with components using connect

* Chore: More TypeScript fixes

* Chore: Update strict check values

* Still need to export these types...

* Declare connector at the top of the file

* Careful with find and replace...
2021-07-23 11:33:26 +02:00

39 lines
1.1 KiB
TypeScript

import React from 'react';
import { css, cx } from '@emotion/css';
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}
/>
);
};