2017-04-21 18:05:35 +00:00
|
|
|
import PropTypes from 'prop-types';
|
2023-05-23 15:15:17 +00:00
|
|
|
import { PureComponent } from 'react';
|
|
|
|
|
2017-02-14 19:59:26 +00:00
|
|
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
2023-05-23 15:15:17 +00:00
|
|
|
|
2023-05-09 01:11:56 +00:00
|
|
|
import { Avatar } from 'mastodon/components/avatar';
|
2023-05-09 21:08:54 +00:00
|
|
|
import { DisplayName } from 'mastodon/components/display_name';
|
2023-05-23 15:15:17 +00:00
|
|
|
import MediaAttachments from 'mastodon/components/media_attachments';
|
2023-05-09 01:11:56 +00:00
|
|
|
import { RelativeTimestamp } from 'mastodon/components/relative_timestamp';
|
2023-05-23 15:15:17 +00:00
|
|
|
import StatusContent from 'mastodon/components/status_content';
|
2023-10-24 17:45:08 +00:00
|
|
|
import { VisibilityIcon } from 'mastodon/components/visibility_icon';
|
2023-05-23 15:15:17 +00:00
|
|
|
|
2022-02-23 19:03:46 +00:00
|
|
|
import Option from './option';
|
2017-02-14 19:59:26 +00:00
|
|
|
|
2023-05-23 08:52:27 +00:00
|
|
|
class StatusCheckBox extends PureComponent {
|
2017-02-14 19:59:26 +00:00
|
|
|
|
2017-05-12 12:44:10 +00:00
|
|
|
static propTypes = {
|
2022-02-23 19:03:46 +00:00
|
|
|
id: PropTypes.string.isRequired,
|
2017-05-12 12:44:10 +00:00
|
|
|
status: ImmutablePropTypes.map.isRequired,
|
|
|
|
checked: PropTypes.bool,
|
|
|
|
onToggle: PropTypes.func.isRequired,
|
2022-09-21 20:46:57 +00:00
|
|
|
intl: PropTypes.object.isRequired,
|
2022-02-23 19:03:46 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
handleStatusesToggle = (value, checked) => {
|
|
|
|
const { onToggle } = this.props;
|
|
|
|
onToggle(value, checked);
|
2017-05-12 12:44:10 +00:00
|
|
|
};
|
|
|
|
|
2017-02-14 19:59:26 +00:00
|
|
|
render () {
|
2023-10-24 17:45:08 +00:00
|
|
|
const { status, checked } = this.props;
|
2022-02-23 19:03:46 +00:00
|
|
|
|
2017-02-14 22:59:46 +00:00
|
|
|
if (status.get('reblog')) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2022-02-23 19:03:46 +00:00
|
|
|
const labelComponent = (
|
|
|
|
<div className='status-check-box__status poll__option__text'>
|
|
|
|
<div className='detailed-status__display-name'>
|
|
|
|
<div className='detailed-status__display-avatar'>
|
|
|
|
<Avatar account={status.get('account')} size={46} />
|
|
|
|
</div>
|
2017-02-14 19:59:26 +00:00
|
|
|
|
2022-03-09 20:15:24 +00:00
|
|
|
<div>
|
2023-10-24 17:45:08 +00:00
|
|
|
<DisplayName account={status.get('account')} /> · <span className='status__visibility-icon'><VisibilityIcon visibility={status.get('visibility')} /></span> <RelativeTimestamp timestamp={status.get('created_at')} />
|
2022-03-09 20:15:24 +00:00
|
|
|
</div>
|
2017-02-14 19:59:26 +00:00
|
|
|
</div>
|
2022-02-23 19:03:46 +00:00
|
|
|
|
|
|
|
<StatusContent status={status} />
|
2023-12-29 16:34:13 +00:00
|
|
|
<MediaAttachments status={status} visible={false} />
|
2017-02-14 19:59:26 +00:00
|
|
|
</div>
|
|
|
|
);
|
2022-02-23 19:03:46 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<Option
|
|
|
|
name='status_ids'
|
|
|
|
value={status.get('id')}
|
|
|
|
checked={checked}
|
|
|
|
onToggle={this.handleStatusesToggle}
|
|
|
|
label={status.get('search_index')}
|
|
|
|
labelComponent={labelComponent}
|
|
|
|
multiple
|
|
|
|
/>
|
|
|
|
);
|
2017-02-14 19:59:26 +00:00
|
|
|
}
|
|
|
|
|
2017-04-21 18:05:35 +00:00
|
|
|
}
|
2023-03-24 02:17:53 +00:00
|
|
|
|
2023-10-24 17:45:08 +00:00
|
|
|
export default StatusCheckBox;
|