2020-03-22 23:14:51 +01:00
|
|
|
import { formatValue } from 'Engine/format'
|
2019-09-13 12:42:19 +02:00
|
|
|
import React, { useCallback, useState } from 'react'
|
2020-03-22 23:14:51 +01:00
|
|
|
import { debounce as debounceFn } from '../utils'
|
2019-04-26 12:41:57 +02:00
|
|
|
import './PercentageField.css'
|
|
|
|
|
2020-03-22 23:14:51 +01:00
|
|
|
export default function PercentageField({ onChange, value, debounce = 0 }) {
|
2019-09-13 12:42:19 +02:00
|
|
|
const [localValue, setLocalValue] = useState(value)
|
|
|
|
const debouncedOnChange = useCallback(
|
2020-03-22 23:14:51 +01:00
|
|
|
debounce ? debounceFn(debounce, onChange) : onChange,
|
2019-09-15 22:51:13 +02:00
|
|
|
[debounce, onChange]
|
2019-09-13 12:42:19 +02:00
|
|
|
)
|
2019-09-11 10:06:26 +02:00
|
|
|
|
|
|
|
return (
|
|
|
|
<div>
|
|
|
|
<input
|
|
|
|
className="range"
|
2019-09-13 12:42:19 +02:00
|
|
|
onChange={e => {
|
|
|
|
const value = e.target.value
|
|
|
|
setLocalValue(value)
|
|
|
|
debouncedOnChange(value)
|
|
|
|
}}
|
2019-09-11 10:06:26 +02:00
|
|
|
type="range"
|
|
|
|
value={localValue}
|
|
|
|
name="volume"
|
|
|
|
min="0"
|
|
|
|
step="0.05"
|
|
|
|
max="1"
|
|
|
|
/>
|
|
|
|
<span style={{ display: 'inline-block', width: '3em' }}>
|
2020-03-22 23:14:51 +01:00
|
|
|
{formatValue({
|
2020-04-21 15:49:48 +02:00
|
|
|
value: localValue,
|
2020-03-22 23:14:51 +01:00
|
|
|
unit: '%'
|
|
|
|
})}
|
2019-09-11 10:06:26 +02:00
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
)
|
2019-04-26 12:41:57 +02:00
|
|
|
}
|