React Native Slider
This lightweight version of a slider is fully compatible with React-Native and React-Native-Web.
It also provides support for Range slider (with 2 thumbs) and custom thumb rendering.
- Same API as @react-native-community/slider (with some more features of course!)
- lightweight
- Range slider for sliders with min and max values
- Supports for React-Native-Web
- No extra dependencies!
data:image/s3,"s3://crabby-images/bf971/bf97138b996e28daa0d683db1ddd19894ffbadd0" alt=""
Try it here!
Have a look at the troubleshooting section if you encounter any issue, or open an issue.
Install
npm i -S @react-native-assets/slider
Usage
Slider
You can see below the available props with their respective default values.
import { Slider } from '@react-native-assets/slider'
<Slider
value={0}
minimumValue={0}
maximumValue={1}
step={0}
minimumTrackTintColor='grey'
maximumTrackTintColor='grey'
thumbTintColor='darkcyan'
thumbStyle={undefined}
trackStyle={undefined}
minTrackStyle={undefined}
maxTrackStyle={undefined}
vertical={false}
inverted={false}
enabled={true}
trackHeight={4}
thumbSize={15}
thumbImage={undefined}
slideOnTap={true}
onValueChange={undefined}
onSlidingStart={undefined}
onSlidingComplete={undefined}
CustomThumb={undefined}
CustomMark={undefined}
{...props}
/>
Range Slider
You can see below the available props with their respective default values
import { RangeSlider } from '@react-native-assets/slider'
<RangeSlider
range={[0, 1]}
minimumValue={0}
maximumValue={1}
step={0}
minimumRange={0}
crossingAllowed={false}
outboundColor='grey'
inboundColor='grey'
thumbTintColor='darkcyan'
thumbStyle={undefined}
trackStyle={undefined}
minTrackStyle={undefined}
midTrackStyle={undefined}
maxTrackStyle={undefined}
vertical={false}
inverted={false}
enabled={true}
trackHeight={4}
thumbSize={15}
thumbImage={undefined}
slideOnTap={true}
onValueChange={undefined}
onSlidingStart={undefined}
onSlidingComplete={undefined}
CustomThumb={undefined}
CustomMark={undefined}
{...props}
/>
Troubleshooting
- The slider is hard to move around
The component is probably too narrow. Increase the height of the component to ensure a correct touch area
- The value gets wrong when my finger gets out of the slider on Android
There is an open issue on React Native project. Meanwhile, you can widen the Slider area using paddings if needed.
Slider V7
Changelog V 7.2.0:
- Improve key navigation and accessibility on range slider
- Move the focusable area on the Thumb instead of the ResponderView
Changelog V 7.1.0:
- Fix the slider value when using step > 1 and minimumValue != 0
- Prevent rerenders in the RangeSlider if the provided value prop has the same bounds as the current range
Changelog V 7.0.0:
- Add CustomMark prop to provide your own component to render the places where the thumb can stop
- Wrap the Responder view inside a wrapper to provide more accurate control over the component
Changelog V 6.0.0:
- Call prevent default on mouse events to avoid weird interactions
- Improve performances
- Add a padding around the RangeSlider too
Changelog V 5.6.3:
- Fix Slider value not updating when provided through props
- Fix a performance issue
Changelog V 5.5.1:
- Fix usage step with minimumValue or maximumValue that don't match the step decimal precision
- Increase the tolerance when using slideOnTap={false}
- Fix value not updating when providing new data to
range
prop in RangeSlider
Changelog V 5.4.0:
- Adding support for
thumbImage
prop (please report if you encounter an issue with it) - Fix slider breaking when providing your own
onLayout
callback
Changelog V 5.3.0:
- new
minTrackStyle
prop on Slider and RangeSlider - new
maxTrackStyle
prop on Slider and RangeSlider - new
midTrackStyle
prop on RangeSlider
Changelog V 5.2.0:
- Adding a default padding of 10 on the ResponderView so that the touches events are more easily catched by the slider.
Changelog V 5.1.0:
- new
crossingAllowed
prop on RangeSlider - new
minimumRange
prop on RangeSlider
Changelog V 5.0.0:
- Remove
AnimatedSlider
and AnimatedRangeSlider
- new
slideOnTap
prop - performance boost
If you have any issue, please fill an issue on our repo