ShadCN-Inspired Tailwind Switch Component
DSy lets you customize switches in real time — choose small or large variants, and adjust default and active states. Copy ShadCN-inspired React/Next.js code.
Install dependency below to use component
npm install @radix-ui/react-switch
Normal State
'use client';
import * as React from 'react';
import * as SwitchPrimitive from '@radix-ui/react-switch';
import { cva, type VariantProps } from 'class-variance-authority';
import { cn } from '@/lib/utils';
const switchVariants = cva(
'peer inline-flex shrink-0 cursor-pointer items-center rounded-full p-0.5 overflow-hidden transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 focus-visible:ring-offset-background disabled:cursor-not-allowed disabled:opacity-50',
{
variants: {
size: {
sm: 'h-5 w-9',
lg: 'h-6 w-11',
},
},
defaultVariants: {
size: 'lg',
},
}
);
const thumbVariants = cva(
'pointer-events-none block rounded-full bg-background shadow-lg ring-0 transition-transform duration-200 ease-in-out',
{
variants: {
size: {
sm: 'h-4 w-4 data-[state=checked]:translate-x-4 data-[state=unchecked]:translate-x-0',
lg: 'h-5 w-5 data-[state=checked]:translate-x-5 data-[state=unchecked]:translate-x-0',
},
},
defaultVariants: {
size: 'lg',
},
}
);
export interface SwitchProps
extends React.ComponentPropsWithoutRef<typeof SwitchPrimitive.Root>,
VariantProps<typeof switchVariants> {}
const Switch = React.forwardRef<
React.ElementRef<typeof SwitchPrimitive.Root>,
SwitchProps
>(({ className, size, checked, ...props }, ref) => {
return (
<SwitchPrimitive.Root
ref={ref}
className={cn(
switchVariants({ size }),
`bg-gray-200`,
className
)}
checked={checked}
{...props}
>
<SwitchPrimitive.Thumb
className={cn(
thumbVariants({ size }),
`bg-white data-[state=checked]:bg-white`
)}
/>
</SwitchPrimitive.Root>
);
});
Switch.displayName = SwitchPrimitive.Root.displayName;
export { Switch };Large
Adjust the size of your switch. This setting affects the overall appearance and feel.