2022-12-15 19:50:11 +02:00
import { FormattedMessage } from 'react-intl' ;
2023-05-23 18:15:17 +03:00
import ImmutablePropTypes from 'react-immutable-proptypes' ;
2022-12-15 19:50:11 +02:00
import ImmutablePureComponent from 'react-immutable-pure-component' ;
2023-05-23 18:15:17 +03:00
2024-01-16 12:27:26 +02:00
import CheckIcon from '@/material-icons/400-24px/check.svg?react' ;
import CloseIcon from '@/material-icons/400-24px/close.svg?react' ;
2023-05-09 04:11:56 +03:00
import { Icon } from 'mastodon/components/icon' ;
2022-12-15 19:50:11 +02:00
export default class FollowRequestNote extends ImmutablePureComponent {
static propTypes = {
2023-11-03 17:00:03 +02:00
account : ImmutablePropTypes . record . isRequired ,
2022-12-15 19:50:11 +02:00
} ;
render ( ) {
const { account , onAuthorize , onReject } = this . props ;
return (
< div className = 'follow-request-banner' >
< div className = 'follow-request-banner__message' >
< FormattedMessage id = 'account.requested_follow' defaultMessage = '{name} has requested to follow you' values = { { name : < bdi > < strong dangerouslySetInnerHTML = { { _ _html : account . get ( 'display_name_html' ) } } / > < / bdi > } } / >
< / div >
< div className = 'follow-request-banner__action' >
< button type = 'button' className = 'button button-tertiary button--confirmation' onClick = { onAuthorize } >
2023-10-24 20:45:08 +03:00
< Icon id = 'check' icon = { CheckIcon } / >
2022-12-15 19:50:11 +02:00
< FormattedMessage id = 'follow_request.authorize' defaultMessage = 'Authorize' / >
< / button >
< button type = 'button' className = 'button button-tertiary button--destructive' onClick = { onReject } >
2023-10-24 20:45:08 +03:00
< Icon id = 'times' icon = { CloseIcon } / >
2022-12-15 19:50:11 +02:00
< FormattedMessage id = 'follow_request.reject' defaultMessage = 'Reject' / >
< / button >
< / div >
< / div >
) ;
}
}