Looking for the old docs? Go here

Sliders

Speed Slider

This component is used to create a range input for controlling the current playback rate.

HTMLAttributes
Ref<SpeedSliderInstance>

Versatile and user-friendly input playback rate control designed for seamless cross-browser and provider compatibility and accessibility with ARIA support. It offers a smooth user experience for both mouse and touch interactions and is highly customizable in terms of styling.

import { SpeedSlider } from "@vidstack/react";

const Component = SpeedSlider.Root;
type Props = SpeedSlider.RootProps;
<SpeedSlider.Root>
  <SpeedSlider.Track>
    <SpeedSlider.TrackFill />
  </SpeedSlider.Track>
  <SpeedSlider.Thumb />
</SpeedSlider.Root>
PropTypeDefault
asChild
boolean
false
children
ReactNode
null
disabled
boolean
undefined
hidden
boolean
undefined
keyStep
number
0.25
max
number
2
min
number
0
orientation
SliderOrientation
undefined
shiftKeyMultiplier
number
2
step
number
0.25
import { SpeedSlider, SpeedSliderInstance } from "@vidstack/react"

const ref = useRef<SpeedSliderInstance>(null),
  { /* state props */ } = useStore(SpeedSliderInstance, ref);

<SpeedSlider.Root ref={ref}>
PropTypeDefault
active
boolean
undefined
dragging
boolean
false
fillPercent
number
undefined
fillRate
number
undefined
focused
boolean
false
hidden
boolean
false
max
number
100
min
number
0
pointerPercent
number
undefined
pointerRate
number
undefined
pointerValue
number
0
pointing
boolean
false
step
number
1
value
number
0
CallbackType
onDragEnd
function
onDragStart
function
onDragValueChange
function
onMediaRateChangeRequest
function
onPointerValueChange
function
onValueChange
function
import { SpeedSlider, type SpeedSliderInstance } from "@vidstack/react"

const ref = useRef<SpeedSliderInstance>(null);

useEffect(() => { /* Use props/methods here. */ }, [])

<SpeedSlider.Root ref={ref}>
PropType
state
SpeedSliderState
subscribe
method
NameDescription
--slider-fill
The fill rate expressed as a percentage.
--slider-pointer
The pointer rate expressed as a percentage.
/* Example. */
.component[data-foo] {}
NameDescription
data-dragging
Whether slider thumb is being dragged.
data-pointing
Whether user's pointing device is over slider.
data-active
Whether slider is being interacted with.
data-focus
Whether slider is being keyboard focused.
data-hocus
Whether slider is being keyboard focused or hovered over.
data-supported
Whether setting playback rate is supported.
HTMLAttributes
Ref<HTMLElement>

Purely visual element used to display a draggable handle to the user for adjusting the value on the slider component.

import { SpeedSlider } from "@vidstack/react";

const Component = SpeedSlider.Thumb;
type Props = SpeedSlider.ThumbProps;
<SpeedSlider.Root>
  <SpeedSlider.Thumb />
</SpeedSlider.Root>
PropTypeDefault
asChild
boolean
false
HTMLAttributes
Ref<HTMLElement>

Visual element inside the slider that serves as a horizontal or vertical bar, providing a visual reference for the range or values that can be selected by moving the slider thumb along it. Users can interact with the slider by dragging the thumb along the track to set a specific value.

import { SpeedSlider } from "@vidstack/react";

const Component = SpeedSlider.Track;
type Props = SpeedSlider.TrackProps;
<SpeedSlider.Root>
  <SpeedSlider.Track>
    <SpeedSlider.TrackFill />
  </SpeedSlider.Track>
</SpeedSlider.Root>
PropTypeDefault
asChild
boolean
false
HTMLAttributes
Ref<HTMLElement>

Portion of the slider track that is visually filled or highlighted to indicate the selected or currently chosen range or value. As the slider thumb is moved along the track, the track fill dynamically adjusts to visually represent the portion of the track that corresponds to the selected value or range, providing users with a clear visual indication of their selection.

import { SpeedSlider } from "@vidstack/react";

const Component = SpeedSlider.TrackFill;
type Props = SpeedSlider.TrackFillProps;
<SpeedSlider.Root>
  <SpeedSlider.Track>
    <SpeedSlider.TrackFill />
  </SpeedSlider.Track>
</SpeedSlider.Root>
PropTypeDefault
asChild
boolean
false
HTMLAttributes
Ref<HTMLElement>

Used to provide users with a real-time or interactive preview of the value or selection they are making as they move the slider thumb. This can include displaying the current pointer value numerically, or displaying a thumbnail over the time slider.

import { SpeedSlider } from "@vidstack/react";

const Component = SpeedSlider.Preview;
type Props = SpeedSlider.PreviewProps;
<SpeedSlider.Root>
  <SpeedSlider.Preview>
    <SpeedSlider.Value />
  </SpeedSlider.Preview>
</SpeedSlider.Root>
PropTypeDefault
asChild
boolean
false
children
ReactNode
null
noClamp
boolean
false
offset
number
0
/* Example. */
.component[data-foo] {}
NameDescription
data-visible
Whether the preview is visible.
HTMLAttributes
Ref<HTMLElement>

Displays the specific numeric representation of the current or pointer value of the slider. When a user interacts with a slider by moving its thumb along the track, the slider value changes accordingly.

import { SpeedSlider } from "@vidstack/react";

const Component = SpeedSlider.Value;
type Props = SpeedSlider.ValueProps;
<SpeedSlider.Root>
  <SpeedSlider.Preview>
    <SpeedSlider.Value />
  </SpeedSlider.Preview>
</SpeedSlider.Root>
PropTypeDefault
asChild
boolean
false
children
ReactNode
null
decimalPlaces
number
2
format
string
null
padHours
boolean
null
padMinutes
boolean
null
showHours
boolean
false
showMs
boolean
false
type
string
'pointer'
HTMLAttributes
Ref<HTMLElement>

Visual markers that can be used to indicate value steps on the slider track.

import { SpeedSlider } from "@vidstack/react";

const Component = SpeedSlider.Steps;
type Props = SpeedSlider.StepsProps;
<SpeedSlider.Root>
  <SpeedSlider.Steps className="steps">
    {(step) => <div className="step" key={String(step)}></div>}
  </SpeedSlider.Steps>
</SpeedSlider.Root>
PropTypeDefault
children
function
null
asChild
boolean
false