Slider
An input where the user selects a value from within a given range.
Playground
Installation
Install in any React + Tailwind project:
$npx shadcn@latest add https://twigs.globirdenergy.com.au/r/slider.json
Source
The exact file the registry serves to consumers.
'use client';
import * as React from 'react';
import { Slider as BaseSlider } from '@base-ui/react/slider';
import { cn } from '@/lib/utils';
function Slider({
className,
defaultValue,
value,
min = 0,
max = 100,
...props
}: React.ComponentProps<typeof BaseSlider.Root>) {
const arr = React.useMemo(
() =>
Array.isArray(value)
? value
: Array.isArray(defaultValue)
? defaultValue
: [min, max],
[value, defaultValue, min, max],
);
return (
<BaseSlider.Root
data-slot="slider"
defaultValue={defaultValue}
value={value}
min={min}
max={max}
className={cn('relative flex w-full touch-none items-center select-none', className)}
{...props}
>
<BaseSlider.Control className="relative flex h-2 w-full items-center">
<BaseSlider.Track className="bg-secondary relative h-2 w-full grow overflow-hidden rounded-full">
<BaseSlider.Indicator className="bg-primary absolute h-full" />
</BaseSlider.Track>
{arr.map((_, i) => (
<BaseSlider.Thumb
key={i}
className="border-primary bg-background block size-4 shrink-0 rounded-full border-2 shadow-sm outline-none transition-shadow focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50"
/>
))}
</BaseSlider.Control>
</BaseSlider.Root>
);
}
export { Slider };