2024-05-07 13:13:55 -04:00
|
|
|
import React, { useState } from 'react';
|
|
|
|
|
import { ToggleContext } from './ToggleContext';
|
|
|
|
|
import { cn } from '~/utils';
|
|
|
|
|
|
|
|
|
|
const HoverToggle = ({
|
|
|
|
|
children,
|
|
|
|
|
isActiveConvo,
|
2024-05-10 03:16:16 +05:30
|
|
|
isPopoverActive,
|
|
|
|
|
setIsPopoverActive,
|
2024-05-07 13:13:55 -04:00
|
|
|
}: {
|
|
|
|
|
children: React.ReactNode;
|
|
|
|
|
isActiveConvo: boolean;
|
2024-05-10 03:16:16 +05:30
|
|
|
isPopoverActive: boolean;
|
|
|
|
|
setIsPopoverActive: (isActive: boolean) => void;
|
2024-05-07 13:13:55 -04:00
|
|
|
}) => {
|
|
|
|
|
const setPopoverActive = (value: boolean) => setIsPopoverActive(value);
|
|
|
|
|
return (
|
|
|
|
|
<ToggleContext.Provider value={{ setPopoverActive }}>
|
|
|
|
|
<div
|
|
|
|
|
className={cn(
|
2024-05-08 22:21:55 -03:00
|
|
|
'peer absolute bottom-0 right-0 top-0 items-center gap-1.5 rounded-r-lg from-gray-500 from-gray-900 pl-2 pr-2 dark:text-white',
|
2024-05-07 13:13:55 -04:00
|
|
|
isPopoverActive || isActiveConvo ? 'flex' : 'hidden group-hover:flex',
|
|
|
|
|
isActiveConvo
|
2024-05-08 22:21:55 -03:00
|
|
|
? 'from-gray-50 from-85% to-transparent group-hover:bg-gradient-to-l group-hover:from-gray-200 dark:from-gray-800 dark:group-hover:from-gray-800'
|
|
|
|
|
: 'z-50 from-gray-200 from-gray-50 from-0% to-transparent hover:bg-gradient-to-l hover:from-gray-200 dark:from-gray-750 dark:from-gray-800 dark:hover:from-gray-800',
|
|
|
|
|
isPopoverActive && !isActiveConvo ? 'from-gray-50 dark:from-gray-800' : '',
|
2024-05-07 13:13:55 -04:00
|
|
|
)}
|
|
|
|
|
>
|
|
|
|
|
{children}
|
|
|
|
|
</div>
|
|
|
|
|
</ToggleContext.Provider>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export default HoverToggle;
|