import React from 'react'; import { defineMessages, useIntl } from 'react-intl'; import { useAppSelector } from 'soapbox/hooks'; import { getFeatures } from 'soapbox/utils/features'; const messages = defineMessages({ following: { id: 'morefollows.following_label', defaultMessage: '…and {count} more {count, plural, one {follow} other {follows}} on remote sites.', }, followers: { id: 'morefollows.followers_label', defaultMessage: '…and {count} more {count, plural, one {follower} other {followers}} on remote sites.', }, }); interface IMoreFollows { visible?: Boolean, count?: number, type: 'following' | 'followers', } const MoreFollows: React.FC<IMoreFollows> = ({ visible = true, count, type }) => { const intl = useIntl(); const features = useAppSelector((state) => getFeatures(state.instance)); const getMessage = () => { return intl.formatMessage(messages[type], { count }); }; // If the instance isn't federating, there are no remote followers if (!features.federating) { return null; } return ( <div className='morefollows-indicator'> <div> <div className='morefollows-indicator__label' style={{ visibility: visible ? 'visible' : 'hidden' }}> {getMessage()} </div> </div> </div> ); }; export default MoreFollows;