2017-05-03 09:04:16 +09:00
import React from 'react' ;
2017-04-11 11:28:52 +09:00
import ImmutablePropTypes from 'react-immutable-proptypes' ;
2017-04-22 03:05:35 +09:00
import PropTypes from 'prop-types' ;
2017-04-12 04:24:17 +09:00
import { defineMessages , injectIntl , FormattedMessage } from 'react-intl' ;
2017-04-11 11:28:52 +09:00
import Button from '../../../components/button' ;
2017-07-12 17:02:51 +09:00
import StatusContent from '../../../../glitch/components/status/content' ;
2017-04-12 04:24:17 +09:00
import Avatar from '../../../components/avatar' ;
import RelativeTimestamp from '../../../components/relative_timestamp' ;
import DisplayName from '../../../components/display_name' ;
2017-05-03 09:04:16 +09:00
import ImmutablePureComponent from 'react-immutable-pure-component' ;
2017-04-11 11:28:52 +09:00
const messages = defineMessages ( {
2017-05-21 00:31:47 +09:00
reblog : { id : 'status.reblog' , defaultMessage : 'Boost' } ,
2017-04-11 11:28:52 +09:00
} ) ;
2017-06-24 02:36:54 +09:00
@ injectIntl
export default class BoostModal extends ImmutablePureComponent {
2017-04-11 11:28:52 +09:00
2017-05-12 21:44:10 +09:00
static contextTypes = {
2017-05-21 00:31:47 +09:00
router : PropTypes . object ,
2017-05-12 21:44:10 +09:00
} ;
static propTypes = {
status : ImmutablePropTypes . map . isRequired ,
onReblog : PropTypes . func . isRequired ,
onClose : PropTypes . func . isRequired ,
2017-05-21 00:31:47 +09:00
intl : PropTypes . object . isRequired ,
2017-05-12 21:44:10 +09:00
} ;
2017-06-01 11:20:10 +09:00
componentDidMount ( ) {
this . button . focus ( ) ;
}
2017-05-12 21:44:10 +09:00
handleReblog = ( ) => {
2017-04-11 11:28:52 +09:00
this . props . onReblog ( this . props . status ) ;
this . props . onClose ( ) ;
2017-04-22 03:05:35 +09:00
}
2017-04-11 11:28:52 +09:00
2017-05-12 21:44:10 +09:00
handleAccountClick = ( e ) => {
2017-04-12 04:24:17 +09:00
if ( e . button === 0 ) {
e . preventDefault ( ) ;
this . props . onClose ( ) ;
2017-06-21 03:40:03 +09:00
this . context . router . history . push ( ` /accounts/ ${ this . props . status . getIn ( [ 'account' , 'id' ] ) } ` ) ;
2017-04-12 04:24:17 +09:00
}
2017-04-22 03:05:35 +09:00
}
2017-04-11 11:28:52 +09:00
2017-06-01 11:20:10 +09:00
setRef = ( c ) => {
this . button = c ;
}
2017-04-11 11:28:52 +09:00
render ( ) {
2017-06-23 23:05:04 +09:00
const { status , intl } = this . props ;
2017-04-11 11:28:52 +09:00
return (
< div className = 'modal-root__modal boost-modal' >
2017-04-12 04:24:17 +09:00
< div className = 'boost-modal__container' >
< div className = 'status light' >
2017-04-23 11:26:55 +09:00
< div className = 'boost-modal__status-header' >
< div className = 'boost-modal__status-time' >
2017-04-12 04:24:17 +09:00
< a href = { status . get ( 'url' ) } className = 'status__relative-time' target = '_blank' rel = 'noopener' > < RelativeTimestamp timestamp = { status . get ( 'created_at' ) } / > < / a >
< / d i v >
2017-04-23 11:26:55 +09:00
< a onClick = { this . handleAccountClick } href = { status . getIn ( [ 'account' , 'url' ] ) } className = 'status__display-name' >
< div className = 'status__avatar' >
2017-08-07 03:59:19 +09:00
< Avatar account = { status . get ( 'account' ) } size = { 48 } / >
2017-04-12 04:24:17 +09:00
< / d i v >
< DisplayName account = { status . get ( 'account' ) } / >
< / a >
< / d i v >
< StatusContent status = { status } / >
< / d i v >
2017-04-11 11:28:52 +09:00
< / d i v >
2017-04-12 04:24:17 +09:00
< div className = 'boost-modal__action-bar' >
2017-04-13 09:15:45 +09:00
< div > < FormattedMessage id = 'boost_modal.combo' defaultMessage = 'You can press {combo} to skip this next time' values = { { combo : < span > Shift + < i c lassName = 'fa fa-retweet' / > < /span> }} / > < / d i v >
2017-06-01 11:20:10 +09:00
< Button text = { intl . formatMessage ( messages . reblog ) } onClick = { this . handleReblog } ref = { this . setRef } / >
2017-04-11 11:28:52 +09:00
< / d i v >
< / d i v >
) ;
}
2017-04-22 03:05:35 +09:00
}