import React, { FC, useState } from 'react'; import { UncontrolledTooltip, Popover, PopoverBody } from 'reactstrap'; import { useTranslation } from 'react-i18next'; import UserPictureList from './User/UserPictureList'; import { withUnstatedContainers } from './UnstatedUtils'; import AppContainer from '~/client/services/AppContainer'; import { IUser } from '../interfaces/user'; type LikeButtonsProps = { hideTotalNumber?: boolean, sumOfLikers: number, likers: IUser[], isGuestUser?: boolean, isLiked?: boolean, onLikeClicked?: ()=>void, } const LikeButtons: FC = (props: LikeButtonsProps) => { const { t } = useTranslation(); const [isPopoverOpen, setIsPopoverOpen] = useState(false); const togglePopover = () => { setIsPopoverOpen(!isPopoverOpen); }; const { hideTotalNumber, isGuestUser, isLiked, sumOfLikers, onLikeClicked, } = props; return (
{ isGuestUser && ( {t('Not available for guest')} )} { !hideTotalNumber && ( <>
{props.likers?.length ? : t('No users have liked this yet.')}
) }
); }; /** * Wrapper component for using unstated */ const LikeButtonsUnstatedWrapper = withUnstatedContainers(LikeButtons, [AppContainer]); // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types const LikeButtonsWrapper = (props) => { return ; }; export default LikeButtonsWrapper;