2022-02-09 00:17:07 +00:00
|
|
|
import React from 'react';
|
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import { FormattedMessage } from 'react-intl';
|
|
|
|
import { closeModal } from 'mastodon/actions/modal';
|
|
|
|
import emojify from 'mastodon/features/emoji/emoji';
|
|
|
|
import escapeTextContentForBrowser from 'escape-html';
|
|
|
|
import InlineAccount from 'mastodon/components/inline_account';
|
|
|
|
import IconButton from 'mastodon/components/icon_button';
|
|
|
|
import RelativeTimestamp from 'mastodon/components/relative_timestamp';
|
2022-03-09 20:15:24 +00:00
|
|
|
import MediaAttachments from 'mastodon/components/media_attachments';
|
2022-02-09 00:17:07 +00:00
|
|
|
|
|
|
|
const mapStateToProps = (state, { statusId }) => ({
|
2023-02-26 19:13:27 +00:00
|
|
|
language: state.getIn(['statuses', statusId, 'language']),
|
2022-02-09 00:17:07 +00:00
|
|
|
versions: state.getIn(['history', statusId, 'items']),
|
|
|
|
});
|
|
|
|
|
|
|
|
const mapDispatchToProps = dispatch => ({
|
|
|
|
|
|
|
|
onClose() {
|
|
|
|
dispatch(closeModal());
|
|
|
|
},
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
class CompareHistoryModal extends React.PureComponent {
|
|
|
|
|
|
|
|
static propTypes = {
|
|
|
|
onClose: PropTypes.func.isRequired,
|
|
|
|
index: PropTypes.number.isRequired,
|
|
|
|
statusId: PropTypes.string.isRequired,
|
2023-02-26 19:13:27 +00:00
|
|
|
language: PropTypes.string.isRequired,
|
2022-02-09 00:17:07 +00:00
|
|
|
versions: ImmutablePropTypes.list.isRequired,
|
|
|
|
};
|
|
|
|
|
|
|
|
render () {
|
2023-02-26 19:13:27 +00:00
|
|
|
const { index, versions, language, onClose } = this.props;
|
2022-02-09 00:17:07 +00:00
|
|
|
const currentVersion = versions.get(index);
|
|
|
|
|
|
|
|
const emojiMap = currentVersion.get('emojis').reduce((obj, emoji) => {
|
|
|
|
obj[`:${emoji.get('shortcode')}:`] = emoji.toJS();
|
|
|
|
return obj;
|
|
|
|
}, {});
|
|
|
|
|
|
|
|
const content = { __html: emojify(currentVersion.get('content'), emojiMap) };
|
|
|
|
const spoilerContent = { __html: emojify(escapeTextContentForBrowser(currentVersion.get('spoiler_text')), emojiMap) };
|
|
|
|
|
|
|
|
const formattedDate = <RelativeTimestamp timestamp={currentVersion.get('created_at')} short={false} />;
|
|
|
|
const formattedName = <InlineAccount accountId={currentVersion.get('account')} />;
|
|
|
|
|
|
|
|
const label = currentVersion.get('original') ? (
|
|
|
|
<FormattedMessage id='status.history.created' defaultMessage='{name} created {date}' values={{ name: formattedName, date: formattedDate }} />
|
|
|
|
) : (
|
|
|
|
<FormattedMessage id='status.history.edited' defaultMessage='{name} edited {date}' values={{ name: formattedName, date: formattedDate }} />
|
|
|
|
);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className='modal-root__modal compare-history-modal'>
|
|
|
|
<div className='report-modal__target'>
|
|
|
|
<IconButton className='report-modal__close' icon='times' onClick={onClose} size={20} />
|
|
|
|
{label}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div className='compare-history-modal__container'>
|
|
|
|
<div className='status__content'>
|
|
|
|
{currentVersion.get('spoiler_text').length > 0 && (
|
|
|
|
<React.Fragment>
|
2023-02-26 19:13:27 +00:00
|
|
|
<div className='translate' dangerouslySetInnerHTML={spoilerContent} lang={language} />
|
2022-02-09 00:17:07 +00:00
|
|
|
<hr />
|
|
|
|
</React.Fragment>
|
|
|
|
)}
|
|
|
|
|
2023-02-26 19:13:27 +00:00
|
|
|
<div className='status__content__text status__content__text--visible translate' dangerouslySetInnerHTML={content} lang={language} />
|
2022-03-09 20:15:24 +00:00
|
|
|
|
|
|
|
{!!currentVersion.get('poll') && (
|
|
|
|
<div className='poll'>
|
|
|
|
<ul>
|
|
|
|
{currentVersion.getIn(['poll', 'options']).map(option => (
|
|
|
|
<li key={option.get('title')}>
|
|
|
|
<span className='poll__input disabled' />
|
|
|
|
|
|
|
|
<span
|
|
|
|
className='poll__option__text translate'
|
|
|
|
dangerouslySetInnerHTML={{ __html: emojify(escapeTextContentForBrowser(option.get('title')), emojiMap) }}
|
2023-02-26 19:13:27 +00:00
|
|
|
lang={language}
|
2022-03-09 20:15:24 +00:00
|
|
|
/>
|
|
|
|
</li>
|
|
|
|
))}
|
|
|
|
</ul>
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
|
2023-02-26 19:13:27 +00:00
|
|
|
<MediaAttachments status={currentVersion} lang={language} />
|
2022-02-09 00:17:07 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2023-03-24 02:17:53 +00:00
|
|
|
|
|
|
|
export default connect(mapStateToProps, mapDispatchToProps)(CompareHistoryModal);
|