import React, { useEffect, useState } from 'react'; import PropTypes from 'prop-types'; import { useSelector, useDispatch } from 'react-redux'; import { makeGetAccount } from 'soapbox/selectors'; import { injectIntl, FormattedMessage } from 'react-intl'; import ImmutablePropTypes from 'react-immutable-proptypes'; import UserPanel from 'soapbox/features/ui/components/user_panel'; import ActionButton from 'soapbox/features/ui/components/action_button'; import { isAdmin, isModerator } from 'soapbox/utils/accounts'; import Badge from 'soapbox/components/badge'; import classNames from 'classnames'; import { fetchRelationships } from 'soapbox/actions/accounts'; import { usePopper } from 'react-popper'; import { closeProfileHoverCard, updateProfileHoverCard, } from 'soapbox/actions/profile_hover_card'; const getAccount = makeGetAccount(); const getBadges = (account) => { let badges = []; if (isAdmin(account)) badges.push(); if (isModerator(account)) badges.push(); if (account.getIn(['patron', 'is_patron'])) badges.push(); return badges; }; const handleMouseEnter = (dispatch) => { return e => { dispatch(updateProfileHoverCard()); }; }; const handleMouseLeave = (dispatch) => { return e => { dispatch(closeProfileHoverCard(true)); }; }; export const ProfileHoverCard = ({ visible }) => { const dispatch = useDispatch(); const [popperElement, setPopperElement] = useState(null); const accountId = useSelector(state => state.getIn(['profile_hover_card', 'accountId'])); const account = useSelector(state => accountId && getAccount(state, accountId)); const targetRef = useSelector(state => state.getIn(['profile_hover_card', 'ref', 'current'])); const badges = account ? getBadges(account) : []; useEffect(() => { if (accountId) dispatch(fetchRelationships([accountId])); }, [dispatch, accountId]); const { styles, attributes } = usePopper(targetRef, popperElement, { modifiers: [{ name: 'offset', options: { offset: [-100, 0], }, }], }); if (!account) return null; const accountBio = { __html: account.get('note_emojified') }; const followedBy = account.getIn(['relationship', 'followed_by']); return (
{followedBy && }
{badges.length > 0 &&
{badges}
} {account.getIn(['source', 'note'], '').length > 0 &&
}
); }; ProfileHoverCard.propTypes = { visible: PropTypes.bool, accountId: PropTypes.string, account: ImmutablePropTypes.map, intl: PropTypes.object.isRequired, }; ProfileHoverCard.defaultProps = { visible: true, }; export default injectIntl(ProfileHoverCard);