mirror of
https://github.com/grafana/grafana.git
synced 2025-02-13 00:55:47 -06:00
* Remove menuShouldPortal from all <Select /> components * fix unit tests * leave menuShouldPortal as an escape hatch * Fix import order
84 lines
2.7 KiB
TypeScript
84 lines
2.7 KiB
TypeScript
import React, { FC } from 'react';
|
|
|
|
import { SelectableValue } from '@grafana/data';
|
|
import { InlineField, InlineFieldRow, Input, Select } from '@grafana/ui';
|
|
|
|
import { ExpressionQuery, ExpressionQuerySettings, ReducerMode, reducerMode, reducerTypes } from '../types';
|
|
|
|
interface Props {
|
|
labelWidth: number;
|
|
refIds: Array<SelectableValue<string>>;
|
|
query: ExpressionQuery;
|
|
onChange: (query: ExpressionQuery) => void;
|
|
}
|
|
|
|
export const Reduce: FC<Props> = ({ labelWidth, onChange, refIds, query }) => {
|
|
const reducer = reducerTypes.find((o) => o.value === query.reducer);
|
|
|
|
const onRefIdChange = (value: SelectableValue<string>) => {
|
|
onChange({ ...query, expression: value.value });
|
|
};
|
|
|
|
const onSelectReducer = (value: SelectableValue<string>) => {
|
|
onChange({ ...query, reducer: value.value });
|
|
};
|
|
|
|
const onSettingsChanged = (settings: ExpressionQuerySettings) => {
|
|
onChange({ ...query, settings: settings });
|
|
};
|
|
|
|
const onModeChanged = (value: SelectableValue<ReducerMode>) => {
|
|
let newSettings: ExpressionQuerySettings;
|
|
switch (value.value) {
|
|
case ReducerMode.ReplaceNonNumbers:
|
|
let replaceWithNumber = 0;
|
|
if (query.settings?.mode === ReducerMode.ReplaceNonNumbers) {
|
|
replaceWithNumber = query.settings?.replaceWithValue ?? 0;
|
|
}
|
|
newSettings = {
|
|
mode: ReducerMode.ReplaceNonNumbers,
|
|
replaceWithValue: replaceWithNumber,
|
|
};
|
|
break;
|
|
default:
|
|
newSettings = {
|
|
mode: value.value,
|
|
};
|
|
}
|
|
onSettingsChanged(newSettings);
|
|
};
|
|
|
|
const onReplaceWithChanged = (e: React.FormEvent<HTMLInputElement>) => {
|
|
const value = e.currentTarget.valueAsNumber;
|
|
onSettingsChanged({ mode: ReducerMode.ReplaceNonNumbers, replaceWithValue: value ?? 0 });
|
|
};
|
|
|
|
const mode = query.settings?.mode ?? ReducerMode.Strict;
|
|
|
|
const replaceWithNumber = () => {
|
|
if (mode !== ReducerMode.ReplaceNonNumbers) {
|
|
return;
|
|
}
|
|
return (
|
|
<InlineField label="Replace With" labelWidth={labelWidth}>
|
|
<Input type="number" width={10} onChange={onReplaceWithChanged} value={query.settings?.replaceWithValue ?? 0} />
|
|
</InlineField>
|
|
);
|
|
};
|
|
|
|
return (
|
|
<InlineFieldRow>
|
|
<InlineField label="Function" labelWidth={labelWidth}>
|
|
<Select options={reducerTypes} value={reducer} onChange={onSelectReducer} width={25} />
|
|
</InlineField>
|
|
<InlineField label="Input" labelWidth={labelWidth}>
|
|
<Select onChange={onRefIdChange} options={refIds} value={query.expression} width={20} />
|
|
</InlineField>
|
|
<InlineField label="Mode" labelWidth={labelWidth}>
|
|
<Select onChange={onModeChanged} options={reducerMode} value={mode} width={25} />
|
|
</InlineField>
|
|
{replaceWithNumber()}
|
|
</InlineFieldRow>
|
|
);
|
|
};
|