import * as React from 'react'; import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; import { useDispatch } from 'react-redux'; import { fetchSuggestions, dismissSuggestion } from 'soapbox/actions/suggestions'; import { Widget } from 'soapbox/components/ui'; import AccountContainer from 'soapbox/containers/account_container'; import { useAppSelector } from 'soapbox/hooks'; import type { Account as AccountEntity } from 'soapbox/types/entities'; const messages = defineMessages({ dismissSuggestion: { id: 'suggestions.dismiss', defaultMessage: 'Dismiss suggestion' }, }); interface IWhoToFollowPanel { limit: number } const WhoToFollowPanel = ({ limit }: IWhoToFollowPanel) => { const dispatch = useDispatch(); const intl = useIntl(); const suggestions = useAppSelector((state) => state.suggestions.items); const suggestionsToRender = suggestions.slice(0, limit); const handleDismiss = (account: AccountEntity) => { dispatch(dismissSuggestion(account.id)); }; React.useEffect(() => { dispatch(fetchSuggestions()); }, []); if (suggestionsToRender.isEmpty()) { return null; } // FIXME: This page actually doesn't look good right now // const handleAction = () => { // history.push('/suggestions'); // }; return ( } // onAction={handleAction} > {suggestionsToRender.map((suggestion) => ( , but it isn't id={suggestion.account} actionIcon={require('@tabler/icons/x.svg')} actionTitle={intl.formatMessage(messages.dismissSuggestion)} onActionClick={handleDismiss} /> ))} ); }; export default WhoToFollowPanel;