parseClick={parseClick}
disabled={!router}
tagLinks={settings.get('tag_misleading_links')}
+ rewriteMentions={settings.get('rewrite_mentions')}
/>
{!isCollapsed || !(muted || !settings.getIn(['collapsed', 'show_action_bar'])) ? (
<StatusActionBar
disabled: PropTypes.bool,
onUpdate: PropTypes.func,
tagLinks: PropTypes.bool,
+ rewriteMentions: PropTypes.string,
};
static defaultProps = {
tagLinks: true,
+ rewriteMentions: 'no',
};
state = {
_updateStatusLinks () {
const node = this.contentsNode;
- const { tagLinks } = this.props;
+ const { tagLinks, rewriteMentions } = this.props;
if (!node) {
return;
if (mention) {
link.addEventListener('click', this.onMentionClick.bind(this, mention), false);
link.setAttribute('title', mention.get('acct'));
+ if (rewriteMentions !== 'no') {
+ while (link.firstChild) link.removeChild(link.firstChild);
+ link.appendChild(document.createTextNode('@'));
+ const acctSpan = document.createElement('span');
+ acctSpan.textContent = rewriteMentions === 'acct' ? mention.get('acct') : mention.get('username');
+ link.appendChild(acctSpan);
+ }
} else if (link.textContent[0] === '#' || (link.previousSibling && link.previousSibling.textContent && link.previousSibling.textContent[link.previousSibling.textContent.length - 1] === '#')) {
link.addEventListener('click', this.onHashtagClick.bind(this, link.text), false);
} else {
parseClick,
disabled,
tagLinks,
+ rewriteMentions,
} = this.props;
const hidden = this.props.onExpandedToggle ? !this.props.expanded : this.state.hidden;
>
<div
ref={this.setContentsRef}
- key={`contents-${tagLinks}`}
+ key={`contents-${tagLinks}-${rewriteMentions}`}
dangerouslySetInnerHTML={content}
lang={status.get('language')}
className='status__content__text'
filters_upstream: { id: 'settings.filtering_behavior.upstream', defaultMessage: 'Show "filtered" like vanilla Mastodon' },
filters_hide: { id: 'settings.filtering_behavior.hide', defaultMessage: 'Show "filtered" and add a button to display why' },
filters_cw: { id: 'settings.filtering_behavior.cw', defaultMessage: 'Still display the post, and add filtered words to content warning' },
+ rewrite_mentions_no: { id: 'settings.rewrite_mentions_no', defaultMessage: 'Do not rewrite mentions' },
+ rewrite_mentions_acct: { id: 'settings.rewrite_mentions_acct', defaultMessage: 'Rewrite with username and domain (when the account is remote)' },
+ rewrite_mentions_username: { id: 'settings.rewrite_mentions_username', defaultMessage: 'Rewrite with username' },
});
@injectIntl
<FormattedMessage id='settings.tag_misleading_links' defaultMessage='Tag misleading links' />
<span className='hint'><FormattedMessage id='settings.tag_misleading_links.hint' defaultMessage="Add a visual indication with the link target host to every link not mentioning it explicitly" /></span>
</LocalSettingsPageItem>
+ <LocalSettingsPageItem
+ settings={settings}
+ item={['rewrite_mentions']}
+ id='mastodon-settings--rewrite_mentions'
+ options={[
+ { value: 'no', message: intl.formatMessage(messages.rewrite_mentions_no) },
+ { value: 'acct', message: intl.formatMessage(messages.rewrite_mentions_acct) },
+ { value: 'username', message: intl.formatMessage(messages.rewrite_mentions_username) },
+ ]}
+ onChange={onChange}
+ >
+ <FormattedMessage id='settings.rewrite_mentions' defaultMessage='Rewrite mentions in displayed statuses' />
+ </LocalSettingsPageItem>
<section>
<h2><FormattedMessage id='settings.notifications_opts' defaultMessage='Notifications options' /></h2>
<LocalSettingsPageItem
parseClick={this.parseClick}
onUpdate={this.handleChildUpdate}
tagLinks={settings.get('tag_misleading_links')}
+ rewriteMentions={settings.get('rewrite_mentions')}
disabled
/>
show_content_type_choice: false,
filtering_behavior: 'hide',
tag_misleading_links: true,
+ rewrite_mentions: 'no',
content_warnings : ImmutableMap({
auto_unfold : false,
filter : null,