2017-12-09 18:26:22 +02:00
import PropTypes from 'prop-types' ;
2023-05-28 17:38:10 +03:00
2017-12-09 18:26:22 +02:00
import { defineMessages , injectIntl , FormattedMessage } from 'react-intl' ;
2023-05-28 17:38:10 +03:00
import classNames from 'classnames' ;
2023-10-19 20:44:55 +03:00
import { withRouter } from 'react-router-dom' ;
2023-05-28 17:38:10 +03:00
import ImmutablePropTypes from 'react-immutable-proptypes' ;
import ImmutablePureComponent from 'react-immutable-pure-component' ;
import AttachmentList from 'flavours/glitch/components/attachment_list' ;
2023-05-09 04:11:56 +03:00
import { Avatar } from 'flavours/glitch/components/avatar' ;
2023-10-23 10:43:00 +03:00
import { Button } from 'flavours/glitch/components/button' ;
2023-05-10 00:08:54 +03:00
import { DisplayName } from 'flavours/glitch/components/display_name' ;
2023-05-09 04:11:56 +03:00
import { Icon } from 'flavours/glitch/components/icon' ;
2023-05-28 17:38:10 +03:00
import { RelativeTimestamp } from 'flavours/glitch/components/relative_timestamp' ;
import StatusContent from 'flavours/glitch/components/status_content' ;
2022-05-03 12:04:09 +03:00
import VisibilityIcon from 'flavours/glitch/components/status_visibility_icon' ;
2023-10-19 20:44:55 +03:00
import { WithRouterPropTypes } from 'flavours/glitch/utils/react_router' ;
2017-12-09 18:26:22 +02:00
const messages = defineMessages ( {
2017-12-09 20:06:00 +02:00
favourite : { id : 'status.favourite' , defaultMessage : 'Favourite' } ,
2017-12-09 18:26:22 +02:00
} ) ;
2019-09-09 16:16:08 +03:00
class FavouriteModal extends ImmutablePureComponent {
2017-12-09 18:26:22 +02:00
static propTypes = {
status : ImmutablePropTypes . map . isRequired ,
2017-12-09 20:06:00 +02:00
onFavourite : PropTypes . func . isRequired ,
2017-12-09 18:26:22 +02:00
onClose : PropTypes . func . isRequired ,
intl : PropTypes . object . isRequired ,
2023-10-19 20:44:55 +03:00
... WithRouterPropTypes ,
2017-12-09 18:26:22 +02:00
} ;
handleFavourite = ( ) => {
this . props . onFavourite ( this . props . status ) ;
this . props . onClose ( ) ;
2023-02-03 21:52:07 +02:00
} ;
2017-12-09 18:26:22 +02:00
handleAccountClick = ( e ) => {
if ( e . button === 0 ) {
e . preventDefault ( ) ;
this . props . onClose ( ) ;
2023-10-19 20:44:55 +03:00
this . props . history . push ( ` /@ ${ this . props . status . getIn ( [ 'account' , 'acct' ] ) } ` ) ;
2017-12-09 18:26:22 +02:00
}
2023-02-03 21:52:07 +02:00
} ;
2017-12-09 18:26:22 +02:00
render ( ) {
const { status , intl } = this . props ;
return (
2022-11-07 11:34:18 +02:00
< div className = 'modal-root__modal boost-modal' >
< div className = 'boost-modal__container' >
2020-11-13 00:25:26 +02:00
< div className = { classNames ( 'status' , ` status- ${ status . get ( 'visibility' ) } ` , 'light' ) } >
2022-11-07 11:34:18 +02:00
< div className = 'boost-modal__status-header' >
< div className = 'boost-modal__status-time' >
2020-11-13 00:25:26 +02:00
< a href = { status . get ( 'url' ) } className = 'status__relative-time' target = '_blank' rel = 'noopener noreferrer' >
2022-05-03 12:04:09 +03:00
< VisibilityIcon visibility = { status . get ( 'visibility' ) } / >
2020-11-13 00:25:26 +02:00
< RelativeTimestamp timestamp = { status . get ( 'created_at' ) } / >
< / a >
2017-12-09 18:26:22 +02:00
< / div >
< a onClick = { this . handleAccountClick } href = { status . getIn ( [ 'account' , 'url' ] ) } className = 'status__display-name' >
< div className = 'status__avatar' >
< Avatar account = { status . get ( 'account' ) } size = { 48 } / >
< / div >
< DisplayName account = { status . get ( 'account' ) } / >
2020-11-13 00:25:26 +02:00
2017-12-09 18:26:22 +02:00
< / a >
< / div >
< StatusContent status = { status } / >
2020-11-13 00:25:26 +02:00
{ status . get ( 'media_attachments' ) . size > 0 && (
< AttachmentList
compact
media = { status . get ( 'media_attachments' ) }
/ >
) }
2017-12-09 18:26:22 +02:00
< / div >
< / div >
2022-11-07 11:34:18 +02:00
< div className = 'boost-modal__action-bar' >
2019-09-09 17:41:41 +03:00
< div > < FormattedMessage id = 'favourite_modal.combo' defaultMessage = 'You can press {combo} to skip this next time' values = { { combo : < span > Shift + < Icon id = 'star' / > < / span > } } / > < / div >
2023-10-23 10:43:00 +03:00
< Button text = { intl . formatMessage ( messages . favourite ) } onClick = { this . handleFavourite } autoFocus / >
2017-12-09 18:26:22 +02:00
< / div >
< / div >
) ;
}
}
2023-03-25 00:15:25 +02:00
2023-10-19 20:44:55 +03:00
export default withRouter ( injectIntl ( FavouriteModal ) ) ;