2020-05-07 09:07:49 -05:00
|
|
|
import React, { useCallback } from 'react';
|
2022-04-22 08:33:13 -05:00
|
|
|
|
2022-06-14 15:42:26 -05:00
|
|
|
import { FieldConfigEditorProps, NumberFieldConfigSettings } from '@grafana/data';
|
|
|
|
|
|
|
|
import { NumberInput } from './NumberInput';
|
2020-03-26 15:48:46 -05:00
|
|
|
|
|
|
|
export const NumberValueEditor: React.FC<FieldConfigEditorProps<number, NumberFieldConfigSettings>> = ({
|
|
|
|
value,
|
|
|
|
onChange,
|
|
|
|
item,
|
|
|
|
}) => {
|
|
|
|
const { settings } = item;
|
2020-05-07 09:07:49 -05:00
|
|
|
|
|
|
|
const onValueChange = useCallback(
|
2022-06-14 15:42:26 -05:00
|
|
|
(value: number | undefined) => {
|
|
|
|
onChange(settings?.integer && value !== undefined ? Math.floor(value) : value);
|
2020-05-07 09:07:49 -05:00
|
|
|
},
|
2020-10-21 02:06:41 -05:00
|
|
|
[onChange, settings?.integer]
|
2020-05-07 09:07:49 -05:00
|
|
|
);
|
|
|
|
|
2020-03-26 15:48:46 -05:00
|
|
|
return (
|
2022-06-14 15:42:26 -05:00
|
|
|
<NumberInput
|
|
|
|
value={value}
|
2020-03-27 06:38:46 -05:00
|
|
|
min={settings?.min}
|
|
|
|
max={settings?.max}
|
|
|
|
step={settings?.step}
|
|
|
|
placeholder={settings?.placeholder}
|
2022-06-14 15:42:26 -05:00
|
|
|
onChange={onValueChange}
|
2020-03-26 15:48:46 -05:00
|
|
|
/>
|
|
|
|
);
|
|
|
|
};
|