You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

58 lines
1.2 KiB

import React from 'react'
import { asField } from 'informed'
import styled, { withTheme } from 'styled-components'
const Input = styled.input`
overflow: hidden;
width: 100%;
appearance: none;
outline: none;
::-webkit-slider-runnable-track {
height: 8px;
appearance: none;
background-color: ${props => props.theme.colors.gray};
margin-top: -1px;
}
::-webkit-slider-thumb {
width: 8px;
appearance: none;
height: 8px;
cursor: ew-resize;
background: ${props => props.theme.colors.primaryText};
box-shadow: -1000px 0 0 1000px orange;
}
`
const Range = asField(({ fieldState, fieldApi, ...props }) => {
const { value } = fieldState
const { setValue, setTouched } = fieldApi
const { onChange, onBlur, forwardedRef, ...rest } = props
return (
<Input
min={0}
max={100}
step={1}
{...rest}
type="range"
ref={forwardedRef}
value={value || 0}
onChange={e => {
setValue(e.target.value)
if (onChange) {
onChange(e)
}
}}
onBlur={e => {
setTouched()
if (onBlur) {
onBlur(e)
}
}}
/>
)
})
export default withTheme(Range)