import React from 'react'; import { defineMessages, useIntl } from 'react-intl'; import { Link } from 'react-router-dom'; import { useAccount } from 'soapbox/api/hooks'; import VerificationBadge from 'soapbox/components/verification-badge'; import { useAppSelector } from 'soapbox/hooks'; import { Card, CardBody, CardTitle, HStack, Stack, Text } from '../../components/ui'; import ActionButton from '../ui/components/action-button'; const messages = defineMessages({ heading: { id: 'feed_suggestions.heading', defaultMessage: 'Suggested Profiles' }, viewAll: { id: 'feed_suggestions.view_all', defaultMessage: 'View all' }, }); interface ISuggestionItem { accountId: string } const SuggestionItem: React.FC = ({ accountId }) => { const { account } = useAccount(accountId); if (!account) return null; return ( {account.acct} {account.verified && } @{account.acct}
); }; const FeedSuggestions = () => { const intl = useIntl(); const suggestedProfiles = useAppSelector((state) => state.suggestions.items); const isLoading = useAppSelector((state) => state.suggestions.isLoading); if (!isLoading && suggestedProfiles.size === 0) return null; return ( {intl.formatMessage(messages.viewAll)} {suggestedProfiles.slice(0, 4).map((suggestedProfile) => ( ))} ); }; export default FeedSuggestions;