f587ff643f
Co-authored-by: Eugen Rochko <eugen@zeonfederated.com> Co-authored-by: Claire <claire.github-309c@sitedethib.com>
49 lines
2.5 KiB
JavaScript
49 lines
2.5 KiB
JavaScript
import PropTypes from 'prop-types';
|
|
|
|
import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
|
|
|
|
import classNames from 'classnames';
|
|
|
|
import HeartBrokenIcon from '@/material-icons/400-24px/heart_broken-fill.svg?react';
|
|
import { Icon } from 'mastodon/components/icon';
|
|
import { domain } from 'mastodon/initial_state';
|
|
|
|
// This needs to be kept in sync with app/models/relationships_severance_event.rb
|
|
const messages = defineMessages({
|
|
account_suspension: { id: 'notification.relationships_severance_event.account_suspension', defaultMessage: 'An admin from {from} has suspended {target}, which means you can no longer receive updates from them or interact with them.' },
|
|
domain_block: { id: 'notification.relationships_severance_event.domain_block', defaultMessage: 'An admin from {from} has blocked {target}, including {followersCount} of your followers and {followingCount, plural, one {# account} other {# accounts}} you follow.' },
|
|
user_domain_block: { id: 'notification.relationships_severance_event.user_domain_block', defaultMessage: 'You have blocked {target}, removing {followersCount} of your followers and {followingCount, plural, one {# account} other {# accounts}} you follow.' },
|
|
});
|
|
|
|
export const RelationshipsSeveranceEvent = ({ type, target, followingCount, followersCount, hidden, unread }) => {
|
|
const intl = useIntl();
|
|
|
|
if (hidden) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<div role='button' className={classNames('notification-group notification-group--link notification-group--relationships-severance-event focusable', { 'notification-group--unread': unread })} tabIndex='0'>
|
|
<div className='notification-group__icon'><Icon id='heart_broken' icon={HeartBrokenIcon} /></div>
|
|
|
|
<div className='notification-group__main'>
|
|
<p>{intl.formatMessage(messages[type], { from: <strong>{domain}</strong>, target: <strong>{target}</strong>, followingCount, followersCount })}</p>
|
|
<a href='/severed_relationships' target='_blank' rel='noopener noreferrer' className='link-button'><FormattedMessage id='notification.relationships_severance_event.learn_more' defaultMessage='Learn more' /></a>
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
RelationshipsSeveranceEvent.propTypes = {
|
|
type: PropTypes.oneOf([
|
|
'account_suspension',
|
|
'domain_block',
|
|
'user_domain_block',
|
|
]).isRequired,
|
|
target: PropTypes.string.isRequired,
|
|
followersCount: PropTypes.number.isRequired,
|
|
followingCount: PropTypes.number.isRequired,
|
|
hidden: PropTypes.bool,
|
|
unread: PropTypes.bool,
|
|
};
|