42 lines
No EOL
1.1 KiB
TypeScript
42 lines
No EOL
1.1 KiB
TypeScript
import React, { useCallback } from 'react';
|
|
import { FormattedMessage } from 'react-intl';
|
|
|
|
import Link from 'soapbox/components/link';
|
|
import { Text } from 'soapbox/components/ui';
|
|
import { useAppSelector } from 'soapbox/hooks';
|
|
import { Group } from 'soapbox/schemas';
|
|
import { makeGetStatus } from 'soapbox/selectors';
|
|
|
|
interface IReplyGroupIndicator {
|
|
composeId: string
|
|
}
|
|
|
|
const ReplyGroupIndicator = (props: IReplyGroupIndicator) => {
|
|
const { composeId } = props;
|
|
|
|
const getStatus = useCallback(makeGetStatus(), []);
|
|
|
|
const status = useAppSelector((state) => getStatus(state, { id: state.compose.get(composeId)?.in_reply_to! }));
|
|
const group = status?.group as Group;
|
|
|
|
if (!group) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<Text theme='muted' size='sm'>
|
|
<FormattedMessage
|
|
id='compose.reply_group_indicator.message'
|
|
defaultMessage='Posting to {groupLink}'
|
|
values={{
|
|
groupLink: <Link
|
|
to={`/group/${group.slug}`}
|
|
dangerouslySetInnerHTML={{ __html: group.display_name_html }}
|
|
/>,
|
|
}}
|
|
/>
|
|
</Text>
|
|
);
|
|
};
|
|
|
|
export default ReplyGroupIndicator; |