import React, { useCallback } from 'react'; import { FormattedList, FormattedMessage } from 'react-intl'; import { useDispatch } from 'react-redux'; import { openModal } from 'soapbox/actions/modals'; import { useAppSelector } from 'soapbox/hooks'; import { statusToMentionsAccountIdsArray } from 'soapbox/reducers/compose'; import { makeGetStatus } from 'soapbox/selectors'; import { getFeatures } from 'soapbox/utils/features'; import type { Status as StatusEntity } from 'soapbox/types/entities'; const ReplyMentions: React.FC = () => { const dispatch = useDispatch(); const getStatus = useCallback(makeGetStatus(), []); const instance = useAppSelector((state) => state.instance); const status = useAppSelector(state => getStatus(state, { id: state.compose.in_reply_to! })); const to = useAppSelector((state) => state.compose.to); const account = useAppSelector((state) => state.accounts.get(state.me)); const { explicitAddressing } = getFeatures(instance); if (!explicitAddressing || !status || !to) { return null; } const parentTo = status && statusToMentionsAccountIdsArray(status, account!); const handleClick = (e: React.MouseEvent) => { e.preventDefault(); dispatch(openModal('REPLY_MENTIONS')); }; if (!parentTo || (parentTo.size === 0)) { return null; } if (to.size === 0) { return ( ); } const accounts = to.slice(0, 2).map((acct: string) => ( @{acct.split('@')[0]} )).toArray(); if (to.size > 2) { accounts.push( , ); } return ( , }} /> ); }; export default ReplyMentions;