| 
									
										
										
										
											2021-10-12 09:35:44 +00:00
										 |  |  | import { useId } from "@radix-ui/react-id"; | 
					
						
							| 
									
										
										
										
											2021-08-09 22:43:57 +00:00
										 |  |  | import * as Label from "@radix-ui/react-label"; | 
					
						
							| 
									
										
										
										
											2021-09-22 19:52:38 +00:00
										 |  |  | import * as PrimitiveSwitch from "@radix-ui/react-switch"; | 
					
						
							| 
									
										
										
										
											2021-10-18 07:02:25 +00:00
										 |  |  | import React, { useState } from "react"; | 
					
						
							| 
									
										
										
										
											2021-08-09 22:43:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-18 07:02:25 +00:00
										 |  |  | import classNames from "@lib/classNames"; | 
					
						
							| 
									
										
										
										
											2021-08-09 22:43:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-18 07:02:25 +00:00
										 |  |  | type SwitchProps = React.ComponentProps<typeof PrimitiveSwitch.Root> & { | 
					
						
							|  |  |  |   label: string; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | export default function Switch(props: SwitchProps) { | 
					
						
							| 
									
										
										
										
											2021-08-09 22:43:57 +00:00
										 |  |  |   const { label, onCheckedChange, ...primitiveProps } = props; | 
					
						
							|  |  |  |   const [checked, setChecked] = useState(props.defaultChecked || false); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const onPrimitiveCheckedChange = (change: boolean) => { | 
					
						
							|  |  |  |     if (onCheckedChange) { | 
					
						
							|  |  |  |       onCheckedChange(change); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     setChecked(change); | 
					
						
							|  |  |  |   }; | 
					
						
							| 
									
										
										
										
											2021-10-12 09:35:44 +00:00
										 |  |  |   const id = useId(); | 
					
						
							| 
									
										
										
										
											2021-08-09 22:43:57 +00:00
										 |  |  |   return ( | 
					
						
							|  |  |  |     <div className="flex items-center h-[20px]"> | 
					
						
							|  |  |  |       <PrimitiveSwitch.Root | 
					
						
							|  |  |  |         className={classNames(checked ? "bg-gray-900" : "bg-gray-400", "rounded-sm w-[36px] p-0.5 h-[20px]")} | 
					
						
							|  |  |  |         checked={checked} | 
					
						
							|  |  |  |         onCheckedChange={onPrimitiveCheckedChange} | 
					
						
							|  |  |  |         {...primitiveProps}> | 
					
						
							|  |  |  |         <PrimitiveSwitch.Thumb | 
					
						
							| 
									
										
										
										
											2021-10-12 09:35:44 +00:00
										 |  |  |           id={id} | 
					
						
							| 
									
										
										
										
											2021-08-09 22:43:57 +00:00
										 |  |  |           className={classNames( | 
					
						
							|  |  |  |             "bg-white w-[16px] h-[16px] block transition-transform", | 
					
						
							|  |  |  |             checked ? "translate-x-[16px]" : "translate-x-0" | 
					
						
							|  |  |  |           )} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       </PrimitiveSwitch.Root> | 
					
						
							|  |  |  |       {label && ( | 
					
						
							| 
									
										
										
										
											2021-10-12 09:35:44 +00:00
										 |  |  |         <Label.Root | 
					
						
							|  |  |  |           htmlFor={id} | 
					
						
							| 
									
										
										
										
											2022-02-01 22:17:37 +00:00
										 |  |  |           className="text-sm font-medium align-text-top cursor-pointer text-neutral-700 ltr:ml-3 rtl:mr-3"> | 
					
						
							| 
									
										
										
										
											2021-08-09 22:43:57 +00:00
										 |  |  |           {label} | 
					
						
							|  |  |  |         </Label.Root> | 
					
						
							|  |  |  |       )} | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | } |