mirror of
https://github.com/NovaOSS/nova-betterchat.git
synced 2024-11-26 03:44:00 +01:00
31 lines
994 B
TypeScript
31 lines
994 B
TypeScript
|
import React from 'react';
|
||
|
|
||
|
const Toggle = ({
|
||
|
label,
|
||
|
isChecked,
|
||
|
setIsChecked,
|
||
|
}: {
|
||
|
label: string;
|
||
|
isChecked: boolean;
|
||
|
setIsChecked: React.Dispatch<React.SetStateAction<boolean>>;
|
||
|
}) => {
|
||
|
return (
|
||
|
<label className='relative flex items-center cursor-pointer'>
|
||
|
<input
|
||
|
type='checkbox'
|
||
|
className='sr-only peer'
|
||
|
checked={isChecked}
|
||
|
onChange={() => {
|
||
|
setIsChecked((prev) => !prev);
|
||
|
}}
|
||
|
/>
|
||
|
<div className="w-9 h-5 bg-gray-200 dark:bg-gray-600 rounded-full peer-checked:after:translate-x-full peer-checked:after:border-white after:content-[''] after:absolute after:top-[2px] after:left-[2px] after:bg-white after:border-gray-300 after:border after:rounded-full after:h-4 after:w-4 after:transition-all dark:border-gray-600 peer-checked:bg-green-500/70"></div>
|
||
|
<span className='ml-3 text-sm font-medium text-gray-900 dark:text-gray-300'>
|
||
|
{label}
|
||
|
</span>
|
||
|
</label>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default Toggle;
|