2022-01-04 12:06:08 -08:00
|
|
|
import PropTypes from 'prop-types';
|
2022-01-10 14:17:52 -08:00
|
|
|
import React from 'react';
|
2022-01-04 12:06:08 -08:00
|
|
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
|
|
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
2022-01-10 14:17:52 -08:00
|
|
|
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
|
|
|
|
import { connect } from 'react-redux';
|
2022-01-10 14:25:06 -08:00
|
|
|
|
2022-01-04 12:06:08 -08:00
|
|
|
import IconButton from 'soapbox/components/icon_button';
|
|
|
|
import { statusToMentionsAccountIdsArray } from 'soapbox/reducers/compose';
|
|
|
|
import { makeGetStatus } from 'soapbox/selectors';
|
2022-01-10 14:25:06 -08:00
|
|
|
|
2022-01-04 12:06:08 -08:00
|
|
|
import Account from '../../reply_mentions/account';
|
|
|
|
|
|
|
|
const messages = defineMessages({
|
|
|
|
close: { id: 'lightbox.close', defaultMessage: 'Close' },
|
|
|
|
confirm: { id: 'confirmations.delete.confirm', defaultMessage: 'Delete' },
|
|
|
|
});
|
|
|
|
|
|
|
|
const makeMapStateToProps = () => {
|
|
|
|
const getStatus = makeGetStatus();
|
|
|
|
|
|
|
|
return state => {
|
|
|
|
const status = getStatus(state, { id: state.getIn(['compose', 'in_reply_to']) });
|
|
|
|
|
|
|
|
if (!status) {
|
|
|
|
return {
|
|
|
|
isReply: false,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
const me = state.get('me');
|
|
|
|
const account = state.getIn(['accounts', me]);
|
|
|
|
|
|
|
|
const mentions = statusToMentionsAccountIdsArray(state, status, account);
|
|
|
|
|
|
|
|
return {
|
|
|
|
mentions,
|
|
|
|
author: status.getIn(['account', 'id']),
|
2022-01-30 09:46:57 -08:00
|
|
|
// to: state.getIn(['compose', 'to']),
|
2022-01-04 12:06:08 -08:00
|
|
|
isReply: true,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2022-01-30 09:46:57 -08:00
|
|
|
class ReplyMentionsModal extends ImmutablePureComponent {
|
2022-01-04 12:06:08 -08:00
|
|
|
|
|
|
|
static propTypes = {
|
2022-01-30 09:46:57 -08:00
|
|
|
mentions: ImmutablePropTypes.OrderedSet,
|
2022-01-04 12:06:08 -08:00
|
|
|
author: PropTypes.string,
|
|
|
|
intl: PropTypes.object.isRequired,
|
|
|
|
onClose: PropTypes.func.isRequired,
|
|
|
|
dispatch: PropTypes.func.isRequired,
|
|
|
|
};
|
|
|
|
|
|
|
|
onClickClose = () => {
|
2022-01-30 09:46:57 -08:00
|
|
|
const { onClose } = this.props;
|
|
|
|
onClose('REPLY_MENTIONS');
|
2022-01-04 12:06:08 -08:00
|
|
|
};
|
|
|
|
|
|
|
|
render() {
|
|
|
|
const { intl, mentions, author } = this.props;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className='modal-root__modal reply-mentions-modal'>
|
|
|
|
<div className='reply-mentions-modal__header'>
|
|
|
|
<IconButton
|
|
|
|
className='reply-mentions-modal__back'
|
|
|
|
src={require('@tabler/icons/icons/arrow-left.svg')}
|
|
|
|
onClick={this.onClickClose}
|
|
|
|
aria-label={intl.formatMessage(messages.close)}
|
|
|
|
title={intl.formatMessage(messages.close)}
|
|
|
|
/>
|
|
|
|
<h3 className='reply-mentions-modal__header__title'>
|
|
|
|
<FormattedMessage id='navigation_bar.in_reply_to' defaultMessage='In reply to' />
|
|
|
|
</h3>
|
|
|
|
</div>
|
|
|
|
<div className='reply-mentions-modal__accounts'>
|
|
|
|
{mentions.map(accountId => <Account key={accountId} accountId={accountId} added author={author === accountId} />)}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2022-01-30 09:46:57 -08:00
|
|
|
export default injectIntl(connect(makeMapStateToProps)(ReplyMentionsModal));
|