ComponentsSlider
Slider
An input where the user selects a value from within a given range.
Usage
import { Slider } from "@/components/ui/slider"<Slider defaultValue={[50]} max={100} step={1} className="w-64" />Examples
Range slider
<Slider defaultValue={[25, 75]} max={100} step={1} className="w-64" />Stepped
<Slider defaultValue={[40]} max={100} step={10} className="w-64" />Disabled
<Slider defaultValue={[50]} max={100} step={1} className="w-64" disabled />Installation
Via CLI
terminal
npx shadcn@latest add @solar-ui/sliderManual
1. Install the following dependency:
terminal
npm install @radix-ui/react-slider2. Copy and paste the following code into your project:
components/ui/slider.tsx
"use client"
import { Slider as SliderPrimitive } from "radix-ui"
import * as React from "react"
import { cn } from "@/lib/utils"
function Slider({
className,
defaultValue,
value,
min = 0,
max = 100,
...props
}: React.ComponentProps<typeof SliderPrimitive.Root>) {
const _values = React.useMemo(
() =>
Array.isArray(value)
? value
: Array.isArray(defaultValue)
? defaultValue
: [min, max],
[value, defaultValue, min, max]
)
return (
<SliderPrimitive.Root
data-slot="slider"
defaultValue={defaultValue}
value={value}
min={min}
max={max}
className={cn(
"data-[orientation=vertical]:min-h-40 relative flex w-full touch-none items-center select-none data-disabled:opacity-50 data-[orientation=vertical]:h-full data-[orientation=vertical]:w-auto data-[orientation=vertical]:flex-col",
className
)}
{...props}
>
<SliderPrimitive.Track
data-slot="slider-track"
className="bg-default-3 rounded-full data-[orientation=horizontal]:h-1 data-[orientation=vertical]:w-1 relative grow overflow-hidden data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full"
>
<SliderPrimitive.Range
data-slot="slider-range"
className="bg-brand-9 absolute select-none data-[orientation=horizontal]:h-full data-[orientation=vertical]:w-full"
/>
</SliderPrimitive.Track>
{Array.from({ length: _values.length }, (_, index) => (
<SliderPrimitive.Thumb
data-slot="slider-thumb"
key={index}
className="border-default-8 ring-default-7 relative size-3 rounded-full border bg-white transition-[color,box-shadow] after:absolute after:-inset-2 hover:ring-3 focus-visible:ring-3 focus-visible:outline-hidden active:ring-3 block shrink-0 select-none disabled:pointer-events-none disabled:opacity-50"
/>
))}
</SliderPrimitive.Root>
)
}
export { Slider }API
Slider
| Prop | Type | Default | Description |
|---|---|---|---|
value | number[] | — | Controlled value of the slider thumb(s). |
defaultValue | number[] | — | Initial value of the slider thumb(s) (uncontrolled). |
min | number | 0 | The minimum value of the range. |
max | number | 100 | The maximum value of the range. |
step | number | 1 | The stepping interval between values. |
disabled | boolean | false | When true, prevents interaction and applies reduced opacity. |
orientation | "horizontal" | "vertical" | "horizontal" | The orientation of the slider. |
onValueChange | (value: number[]) => void | — | Callback fired continuously as the thumb is dragged. |
onValueCommit | (value: number[]) => void | — | Callback fired when the thumb is released. |
Last updated on