|
|
@ -32,6 +32,7 @@ const messages = defineMessages({ |
|
|
|
embed: { id: 'status.embed', defaultMessage: 'Embed' }, |
|
|
|
embed: { id: 'status.embed', defaultMessage: 'Embed' }, |
|
|
|
admin_account: { id: 'status.admin_account', defaultMessage: 'Open moderation interface for @{name}' }, |
|
|
|
admin_account: { id: 'status.admin_account', defaultMessage: 'Open moderation interface for @{name}' }, |
|
|
|
admin_status: { id: 'status.admin_status', defaultMessage: 'Open this status in the moderation interface' }, |
|
|
|
admin_status: { id: 'status.admin_status', defaultMessage: 'Open this status in the moderation interface' }, |
|
|
|
|
|
|
|
copy: { id: 'status.copy', defaultMessage: 'Copy link to status' }, |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
const obfuscatedCount = count => { |
|
|
|
const obfuscatedCount = count => { |
|
|
@ -141,6 +142,25 @@ class StatusActionBar extends ImmutablePureComponent { |
|
|
|
this.props.onMuteConversation(this.props.status); |
|
|
|
this.props.onMuteConversation(this.props.status); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
handleCopy = () => { |
|
|
|
|
|
|
|
const url = this.props.status.get('url'); |
|
|
|
|
|
|
|
const textarea = document.createElement('textarea'); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
textarea.textContent = url; |
|
|
|
|
|
|
|
textarea.style.position = 'fixed'; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
document.body.appendChild(textarea); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
textarea.select(); |
|
|
|
|
|
|
|
document.execCommand('copy'); |
|
|
|
|
|
|
|
} catch (e) { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} finally { |
|
|
|
|
|
|
|
document.body.removeChild(textarea); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
render () { |
|
|
|
render () { |
|
|
|
const { status, intl, withDismiss } = this.props; |
|
|
|
const { status, intl, withDismiss } = this.props; |
|
|
|
|
|
|
|
|
|
|
@ -156,6 +176,7 @@ class StatusActionBar extends ImmutablePureComponent { |
|
|
|
menu.push({ text: intl.formatMessage(messages.open), action: this.handleOpen }); |
|
|
|
menu.push({ text: intl.formatMessage(messages.open), action: this.handleOpen }); |
|
|
|
|
|
|
|
|
|
|
|
if (publicStatus) { |
|
|
|
if (publicStatus) { |
|
|
|
|
|
|
|
menu.push({ text: intl.formatMessage(messages.copy), action: this.handleCopy }); |
|
|
|
menu.push({ text: intl.formatMessage(messages.embed), action: this.handleEmbed }); |
|
|
|
menu.push({ text: intl.formatMessage(messages.embed), action: this.handleEmbed }); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -184,6 +205,7 @@ class StatusActionBar extends ImmutablePureComponent { |
|
|
|
menu.push({ text: intl.formatMessage(messages.mute, { name: status.getIn(['account', 'username']) }), action: this.handleMuteClick }); |
|
|
|
menu.push({ text: intl.formatMessage(messages.mute, { name: status.getIn(['account', 'username']) }), action: this.handleMuteClick }); |
|
|
|
menu.push({ text: intl.formatMessage(messages.block, { name: status.getIn(['account', 'username']) }), action: this.handleBlockClick }); |
|
|
|
menu.push({ text: intl.formatMessage(messages.block, { name: status.getIn(['account', 'username']) }), action: this.handleBlockClick }); |
|
|
|
menu.push({ text: intl.formatMessage(messages.report, { name: status.getIn(['account', 'username']) }), action: this.handleReport }); |
|
|
|
menu.push({ text: intl.formatMessage(messages.report, { name: status.getIn(['account', 'username']) }), action: this.handleReport }); |
|
|
|
|
|
|
|
|
|
|
|
if (isStaff) { |
|
|
|
if (isStaff) { |
|
|
|
menu.push(null); |
|
|
|
menu.push(null); |
|
|
|
menu.push({ text: intl.formatMessage(messages.admin_account, { name: status.getIn(['account', 'username']) }), href: `/admin/accounts/${status.getIn(['account', 'id'])}` }); |
|
|
|
menu.push({ text: intl.formatMessage(messages.admin_account, { name: status.getIn(['account', 'username']) }), href: `/admin/accounts/${status.getIn(['account', 'id'])}` }); |
|
|
|