import { OrderedSet as ImmutableOrderedSet } from 'immutable'; import React, { useEffect } from 'react'; import { FormattedList, FormattedMessage } from 'react-intl'; import { Link } from 'react-router-dom'; import { fetchAccountFamiliarFollowers } from 'soapbox/actions/familiar-followers'; import { openModal } from 'soapbox/actions/modals'; import AvatarStack from 'soapbox/components/avatar-stack'; import HoverRefWrapper from 'soapbox/components/hover-ref-wrapper'; import { HStack, Text } from 'soapbox/components/ui'; import VerificationBadge from 'soapbox/components/verification-badge'; import { useAppDispatch, useAppSelector, useFeatures } from 'soapbox/hooks'; import { makeGetAccount } from 'soapbox/selectors'; import type { Account } from 'soapbox/types/entities'; const getAccount = makeGetAccount(); interface IProfileFamiliarFollowers { account: Account } const ProfileFamiliarFollowers: React.FC = ({ account }) => { const dispatch = useAppDispatch(); const me = useAppSelector((state) => state.me); const features = useFeatures(); const familiarFollowerIds = useAppSelector(state => state.user_lists.familiar_followers.get(account.id)?.items || ImmutableOrderedSet()); const familiarFollowers: ImmutableOrderedSet = useAppSelector(state => familiarFollowerIds.slice(0, 2).map(accountId => getAccount(state, accountId))); useEffect(() => { if (me && features.familiarFollowers) { dispatch(fetchAccountFamiliarFollowers(account.id)); } }, [account.id]); const openFamiliarFollowersModal = () => { dispatch(openModal('FAMILIAR_FOLLOWERS', { accountId: account.id, })); }; if (familiarFollowerIds.size === 0) { return null; } const accounts: Array = familiarFollowers.map(account => !!account && ( {/* */} {account.verified && } )).toArray(); if (familiarFollowerIds.size > 2) { accounts.push( , ); } return ( , }} /> ); }; export default ProfileFamiliarFollowers;