"use client"; import * as React from "react"; import * as SwitchPrimitives from "@radix-ui/react-switch"; import { cva, type VariantProps } from "class-variance-authority"; import { cn } from "@/src/utils/tailwind"; const switchVariants = cva( "peer inline-flex shrink-0 cursor-pointer items-center rounded-full border-2 border-transparent 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 data-[state=checked]:bg-primary data-[state=unchecked]:bg-input dark:data-[state=unchecked]:bg-muted-foreground", { variants: { size: { default: "h-5 w-9", sm: "h-4 w-7", }, }, defaultVariants: { size: "default", }, }, ); const switchThumbVariants = cva( "pointer-events-none block rounded-full bg-background shadow-lg ring-0 transition-transform data-[state=unchecked]:translate-x-0", { variants: { size: { default: "h-4 w-4 data-[state=checked]:translate-x-4", sm: "h-3 w-3 data-[state=checked]:translate-x-3", }, }, defaultVariants: { size: "default", }, }, ); interface SwitchProps extends React.ComponentPropsWithoutRef, VariantProps {} const Switch = React.forwardRef< React.ElementRef, SwitchProps >(({ className, size, ...props }, ref) => ( )); Switch.displayName = SwitchPrimitives.Root.displayName; export { Switch };