2022-09-13 01:21:56 -07:00
|
|
|
import React, { useCallback } from 'react';
|
2022-05-16 11:30:42 -07:00
|
|
|
import { FormattedList, FormattedMessage } from 'react-intl';
|
2022-04-10 01:48:56 -07:00
|
|
|
import { useDispatch } from 'react-redux';
|
|
|
|
|
|
|
|
import { openModal } from 'soapbox/actions/modals';
|
2022-11-26 08:38:16 -08:00
|
|
|
import { useAppSelector, useCompose, useFeatures } from 'soapbox/hooks';
|
2022-04-10 01:48:56 -07:00
|
|
|
import { statusToMentionsAccountIdsArray } from 'soapbox/reducers/compose';
|
|
|
|
import { makeGetStatus } from 'soapbox/selectors';
|
|
|
|
|
|
|
|
import type { Status as StatusEntity } from 'soapbox/types/entities';
|
|
|
|
|
2022-09-10 14:52:06 -07:00
|
|
|
interface IReplyMentions {
|
|
|
|
composeId: string,
|
|
|
|
}
|
|
|
|
|
|
|
|
const ReplyMentions: React.FC<IReplyMentions> = ({ composeId }) => {
|
2022-04-10 01:48:56 -07:00
|
|
|
const dispatch = useDispatch();
|
2022-11-26 08:38:16 -08:00
|
|
|
const features = useFeatures();
|
2022-09-14 11:01:00 -07:00
|
|
|
const compose = useCompose(composeId);
|
|
|
|
|
2022-11-26 08:38:16 -08:00
|
|
|
const getStatus = useCallback(makeGetStatus(), []);
|
2022-09-16 06:40:29 -07:00
|
|
|
const status = useAppSelector<StatusEntity | null>(state => getStatus(state, { id: compose.in_reply_to! }));
|
2022-09-14 11:01:00 -07:00
|
|
|
const to = compose.to;
|
2022-04-10 01:48:56 -07:00
|
|
|
const account = useAppSelector((state) => state.accounts.get(state.me));
|
|
|
|
|
2022-11-26 08:38:16 -08:00
|
|
|
if (!features.explicitAddressing || !status || !to) {
|
2022-04-10 01:48:56 -07:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2022-06-20 10:59:51 -07:00
|
|
|
const parentTo = status && statusToMentionsAccountIdsArray(status, account!);
|
2022-04-10 01:48:56 -07:00
|
|
|
|
|
|
|
const handleClick = (e: React.MouseEvent<HTMLAnchorElement>) => {
|
|
|
|
e.preventDefault();
|
|
|
|
|
2022-09-22 13:00:32 -07:00
|
|
|
dispatch(openModal('REPLY_MENTIONS', {
|
|
|
|
composeId,
|
|
|
|
}));
|
2022-04-10 01:48:56 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
if (!parentTo || (parentTo.size === 0)) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (to.size === 0) {
|
|
|
|
return (
|
|
|
|
<a href='#' className='reply-mentions' onClick={handleClick}>
|
|
|
|
<FormattedMessage
|
|
|
|
id='reply_mentions.reply_empty'
|
|
|
|
defaultMessage='Replying to post'
|
|
|
|
/>
|
|
|
|
</a>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-05-16 11:30:42 -07:00
|
|
|
const accounts = to.slice(0, 2).map((acct: string) => (
|
|
|
|
<span className='reply-mentions__account'>@{acct.split('@')[0]}</span>
|
|
|
|
)).toArray();
|
|
|
|
|
|
|
|
if (to.size > 2) {
|
|
|
|
accounts.push(
|
|
|
|
<FormattedMessage id='reply_mentions.more' defaultMessage='{count} more' values={{ count: to.size - 2 }} />,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-04-10 01:48:56 -07:00
|
|
|
return (
|
|
|
|
<a href='#' className='reply-mentions' onClick={handleClick}>
|
|
|
|
<FormattedMessage
|
|
|
|
id='reply_mentions.reply'
|
2022-05-16 11:30:42 -07:00
|
|
|
defaultMessage='Replying to {accounts}'
|
2022-04-10 01:48:56 -07:00
|
|
|
values={{
|
2022-05-16 11:30:42 -07:00
|
|
|
accounts: <FormattedList type='conjunction' value={accounts} />,
|
2022-04-10 01:48:56 -07:00
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</a>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default ReplyMentions;
|