Files
d1a2f309-b9fe-4acd-a8cc-cf0…/research/lovable/switch.md
2026-04-28 15:30:34 +03:00

1.1 KiB

import * as React from "react"; import * as SwitchPrimitives from "@radix-ui/react-switch";

import { cn } from "@/lib/utils";

const Switch = React.forwardRef< React.ElementRef, React.ComponentPropsWithoutRef

(({ className, ...props }, ref) => ( <SwitchPrimitives.Root className={cn( "peer inline-flex h-6 w-11 shrink-0 cursor-pointer items-center rounded-full border-2 border-transparent transition-colors data-[state=checked]:bg-primary data-[state=unchecked]:bg-input 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", className, )} {...props} ref={ref}

<SwitchPrimitives.Thumb
  className={cn(
    "pointer-events-none block h-5 w-5 rounded-full bg-background shadow-lg ring-0 transition-transform data-[state=checked]:translate-x-5 data-[state=unchecked]:translate-x-0",
  )}
/>

</SwitchPrimitives.Root> )); Switch.displayName = SwitchPrimitives.Root.displayName;

export { Switch };