@graphistry/rc-slider v8.3.3
rc-slider
Slider UI component for React
Forked from react-component/rc-slider. This one
will update the slider position if you re-render it with a new defaultValue. This makes
it possible to use it as an uncontrolled component, but still programmatically update the
slider position from props, without putting it into fully-controlled mode.
Screenshots
Features
- Supports IE9, IE9+, Chrome, Firefox & Safari
Install
npm install --save @graphistry/rc-sliderUsage
import React from 'react';
import ReactDOM from 'react-dom';
import Slider, { Range } from '@graphistry/rc-slider';
// We can just import Slider or Range to reduce bundle size
// import Slider from '@graphistry/rc-slider/lib/Slider';
// import Range from '@graphistry/rc-slider/lib/Range';
import '@graphistry/rc-slider/assets/index.css';
ReactDOM.render(
  <div>
    <Slider />
    <Range />
  </div>,
  container
);API
createSliderWithTooltip(Slider | Range) => React.Component
An extension to make Slider or Range support Tooltip on handle.
const Slider = require('@graphistry/rc-slider');
const createSliderWithTooltip = Slider.createSliderWithTooltip;
const Range = createSliderWithTooltip(Slider.Range);After Range or Slider was wrapped by createSliderWithTooltip, it will have the following props:
| Name | Type | Default | Description | 
|---|---|---|---|
| tipFormatter | (value: number): React.ReactNode | value => value | A function to format tooltip's overlay | 
| tipProps | Object | {placement: 'top',prefixCls: 'rc-slider-tooltip',overlay: tipFormatter(value)} | A function to format tooltip's overlay | 
Common API
The following APIs are shared by Slider and Range.
| Name | Type | Default | Description | |
|---|---|---|---|---|
| className | string | '' | Additional CSS class for the root DOM node | |
| min | number | 0 | The minimum value of the slider | |
| max | number | 100 | The maximum value of the slider | |
| marks | {number: string}or{number: { style, label }} | {} | Marks on the slider. The key determines the position, and the value determines what will show. If you want to set the style of a specific mark point, the value should be an object which contains styleandlabelproperties. | |
| step | number or null | 1 | Value to be added or subtracted on each step the slider makes. Must be greater than zero, and max-minshould be evenly divisible by the step value.  Whenmarksis not an empty object,stepcan be set tonull, to makemarksas steps. | |
| vertical | boolean | false | If vertical is true, the slider will be vertical. | |
| handle | (props) => React.ReactNode | A handle generator which could be used to customized handle. | ||
| included | boolean | true | If the value is true, it means a continuous value interval, otherwise, it is a independent value. | |
| disabled | boolean | false | If true, handles can't be moved. | |
| dots | boolean | false | When the stepvalue is greater than 1, you can set thedotstotrueif you want to render the slider with dots. | |
| onBeforeChange | Function | NOOP | onBeforeChangewill be triggered whenontouchstartoronmousedownis triggered. | |
| onChange | Function | NOOP | onChangewill be triggered while the value of Slider changing. | |
| onAfterChange | Function | NOOP | onAfterChangewill be triggered whenontouchendoronmouseupis triggered. | |
| minimumTrackStyle | Object | please use trackStyleinstead. (only used for slider, just for compatibility , will be deprecate at rc-slider@9.x) | ||
| maximumTrackStyle | Object | please use railStyleinstead (only used for slider, just for compatibility , will be deprecate at rc-slider@9.x) | ||
| handleStyle | ArrayObject | Object | [{}] | The style used for handle. ( both for slider(Object) and range(Array of Object), the array will be used for mutli handle follow element order) | |
| trackStyle | ArrayObject | Object | [{}] | The style used for track. ( both for slider(Object) and range(Array of Object), the array will be used for mutli track follow element order) | w | 
| railStyle | Object | {} | The style used for the track base color. | |
| dotStyle | Object | {} | The style used for the dots. | |
| activeDotStyle | Object | {} | The style used for the active dots. | 
Slider
| Name | Type | Default | Description | 
|---|---|---|---|
| defaultValue | number | 0 | Set initial value of slider. | 
| value | number | - | Set current value of slider. | 
Range
| Name | Type | Default | Description | 
|---|---|---|---|
| defaultValue | number[] | [0, 0] | Set initial positions of handles. | 
| value | number[] | Set current positions of handles. | |
| count | number | 1 | Determine how many ranges to render, and multiple handles will be rendered (number + 1). | 
| allowCross | boolean | true | allowCrosscould be set astrueto allow those handles to cross. | 
| pushable | boolean or number | false | pushablecould be set astrueto allow pushing of surrounding handles when moving an handle. When set to a number, the number will be the minimum ensured distance between handles. Example: | 
Development
npm install
npm startExample
npm start and then go to http://localhost:8005/examples/
Online examples: http://react-component.github.io/slider/
Test Case
http://localhost:8005/tests/runner.html?coverage
Coverage
http://localhost:8005/node_modules/rc-server/node_modules/node-jscover/lib/front-end/jscoverage.html?w=http://localhost:8088/tests/runner.html?coverage
License
@graphistry/rc-slider is released under the MIT license.
