8 changed files with 138 additions and 20 deletions
@ -0,0 +1,26 @@ |
|||
import React from 'react'; |
|||
|
|||
import { Switch } from '@headlessui/react'; |
|||
|
|||
export interface ToggleProps { |
|||
enabled: boolean; |
|||
setEnabled: (state: boolean) => void; |
|||
} |
|||
|
|||
export const Toggle = ({ enabled, setEnabled }: ToggleProps): JSX.Element => { |
|||
return ( |
|||
<Switch |
|||
checked={enabled} |
|||
onChange={setEnabled} |
|||
className={`${enabled ? 'bg-primary' : 'bg-gray-300 dark:bg-gray-700'} |
|||
relative inline-flex flex-shrink-0 h-[38px] w-[74px] border-2 border-transparent rounded-full cursor-pointer transition-colors ease-in-out duration-200 focus:outline-none focus-visible:ring-2 focus-visible:ring-white focus-visible:ring-opacity-75`}
|
|||
> |
|||
<span className="sr-only">Use setting</span> |
|||
<span |
|||
aria-hidden="true" |
|||
className={`${enabled ? 'translate-x-9' : 'translate-x-0'} |
|||
pointer-events-none inline-block h-[34px] w-[34px] rounded-full bg-white shadow-lg transform ring-0 transition ease-in-out duration-200`}
|
|||
/> |
|||
</Switch> |
|||
); |
|||
}; |
|||
Loading…
Reference in new issue