mirror of
https://github.com/grafana/grafana.git
synced 2025-02-16 18:34:52 -06:00
30 lines
774 B
TypeScript
30 lines
774 B
TypeScript
import React, { useCallback } from 'react';
|
|
|
|
import { FieldConfigEditorProps, NumberFieldConfigSettings } from '@grafana/data';
|
|
|
|
import { NumberInput } from './NumberInput';
|
|
|
|
type Props = FieldConfigEditorProps<number, NumberFieldConfigSettings>;
|
|
|
|
export const NumberValueEditor = ({ value, onChange, item }: Props) => {
|
|
const { settings } = item;
|
|
|
|
const onValueChange = useCallback(
|
|
(value: number | undefined) => {
|
|
onChange(settings?.integer && value !== undefined ? Math.floor(value) : value);
|
|
},
|
|
[onChange, settings?.integer]
|
|
);
|
|
|
|
return (
|
|
<NumberInput
|
|
value={value}
|
|
min={settings?.min}
|
|
max={settings?.max}
|
|
step={settings?.step}
|
|
placeholder={settings?.placeholder}
|
|
onChange={onValueChange}
|
|
/>
|
|
);
|
|
};
|