2023-05-23 17:15:17 +02:00
import { defineMessages , injectIntl } from 'react-intl' ;
2019-01-16 19:47:46 +01:00
import { connect } from 'react-redux' ;
2023-05-23 17:15:17 +02:00
import { showAlertForError } from '../../../actions/alerts' ;
import { initBlockModal } from '../../../actions/blocks' ;
import { initBoostModal } from '../../../actions/boosts' ;
2019-01-16 19:47:46 +01:00
import {
replyCompose ,
mentionCompose ,
directCompose ,
} from '../../../actions/compose' ;
import {
reblog ,
favourite ,
unreblog ,
unfavourite ,
pin ,
unpin ,
} from '../../../actions/interactions' ;
2023-05-23 17:15:17 +02:00
import { openModal } from '../../../actions/modal' ;
import { initMuteModal } from '../../../actions/mutes' ;
import { initReport } from '../../../actions/reports' ;
2019-01-16 19:47:46 +01:00
import {
muteStatus ,
unmuteStatus ,
deleteStatus ,
hideStatus ,
revealStatus ,
} from '../../../actions/statuses' ;
import { boostModal , deleteModal } from '../../../initial_state' ;
2023-05-23 17:15:17 +02:00
import { makeGetStatus , makeGetPictureInPicture } from '../../../selectors' ;
import DetailedStatus from '../components/detailed_status' ;
2019-01-16 19:47:46 +01:00
const messages = defineMessages ( {
deleteConfirm : { id : 'confirmations.delete.confirm' , defaultMessage : 'Delete' } ,
deleteMessage : { id : 'confirmations.delete.message' , defaultMessage : 'Are you sure you want to delete this status?' } ,
redraftConfirm : { id : 'confirmations.redraft.confirm' , defaultMessage : 'Delete & redraft' } ,
2023-07-21 19:09:13 +02:00
redraftMessage : { id : 'confirmations.redraft.message' , defaultMessage : 'Are you sure you want to delete this status and re-draft it? Favorites and boosts will be lost, and replies to the original post will be orphaned.' } ,
2019-01-16 19:47:46 +01:00
replyConfirm : { id : 'confirmations.reply.confirm' , defaultMessage : 'Reply' } ,
replyMessage : { id : 'confirmations.reply.message' , defaultMessage : 'Replying now will overwrite the message you are currently composing. Are you sure you want to proceed?' } ,
} ) ;
const makeMapStateToProps = ( ) => {
const getStatus = makeGetStatus ( ) ;
2020-12-09 04:33:33 +01:00
const getPictureInPicture = makeGetPictureInPicture ( ) ;
2019-01-16 19:47:46 +01:00
const mapStateToProps = ( state , props ) => ( {
status : getStatus ( state , props ) ,
domain : state . getIn ( [ 'meta' , 'domain' ] ) ,
2020-12-09 04:33:33 +01:00
pictureInPicture : getPictureInPicture ( state , props ) ,
2019-01-16 19:47:46 +01:00
} ) ;
return mapStateToProps ;
} ;
const mapDispatchToProps = ( dispatch , { intl } ) => ( {
onReply ( status , router ) {
dispatch ( ( _ , getState ) => {
let state = getState ( ) ;
if ( state . getIn ( [ 'compose' , 'text' ] ) . trim ( ) . length !== 0 ) {
2023-05-25 15:42:37 +02:00
dispatch ( openModal ( {
modalType : 'CONFIRM' ,
modalProps : {
message : intl . formatMessage ( messages . replyMessage ) ,
confirm : intl . formatMessage ( messages . replyConfirm ) ,
onConfirm : ( ) => dispatch ( replyCompose ( status , router ) ) ,
} ,
2019-01-16 19:47:46 +01:00
} ) ) ;
} else {
dispatch ( replyCompose ( status , router ) ) ;
}
} ) ;
} ,
2021-02-11 00:53:12 +01:00
onModalReblog ( status , privacy ) {
dispatch ( reblog ( status , privacy ) ) ;
2019-01-16 19:47:46 +01:00
} ,
onReblog ( status , e ) {
if ( status . get ( 'reblogged' ) ) {
dispatch ( unreblog ( status ) ) ;
} else {
if ( e . shiftKey || ! boostModal ) {
this . onModalReblog ( status ) ;
} else {
2021-02-11 00:53:12 +01:00
dispatch ( initBoostModal ( { status , onReblog : this . onModalReblog } ) ) ;
2019-01-16 19:47:46 +01:00
}
}
} ,
onFavourite ( status ) {
if ( status . get ( 'favourited' ) ) {
dispatch ( unfavourite ( status ) ) ;
} else {
dispatch ( favourite ( status ) ) ;
}
} ,
onPin ( status ) {
if ( status . get ( 'pinned' ) ) {
dispatch ( unpin ( status ) ) ;
} else {
dispatch ( pin ( status ) ) ;
}
} ,
onEmbed ( status ) {
2023-05-25 15:42:37 +02:00
dispatch ( openModal ( {
modalType : 'EMBED' ,
modalProps : {
2023-07-13 15:53:03 +02:00
id : status . get ( 'id' ) ,
2023-05-25 15:42:37 +02:00
onError : error => dispatch ( showAlertForError ( error ) ) ,
} ,
2019-01-16 19:47:46 +01:00
} ) ) ;
} ,
onDelete ( status , history , withRedraft = false ) {
if ( ! deleteModal ) {
dispatch ( deleteStatus ( status . get ( 'id' ) , history , withRedraft ) ) ;
} else {
2023-05-25 15:42:37 +02:00
dispatch ( openModal ( {
modalType : 'CONFIRM' ,
modalProps : {
message : intl . formatMessage ( withRedraft ? messages . redraftMessage : messages . deleteMessage ) ,
confirm : intl . formatMessage ( withRedraft ? messages . redraftConfirm : messages . deleteConfirm ) ,
onConfirm : ( ) => dispatch ( deleteStatus ( status . get ( 'id' ) , history , withRedraft ) ) ,
} ,
2019-01-16 19:47:46 +01:00
} ) ) ;
}
} ,
onDirect ( account , router ) {
dispatch ( directCompose ( account , router ) ) ;
} ,
onMention ( account , router ) {
dispatch ( mentionCompose ( account , router ) ) ;
} ,
2023-05-11 12:41:55 +02:00
onOpenMedia ( media , index , lang ) {
2023-05-25 15:42:37 +02:00
d ispatch ( openModal ( {
modalType : 'MEDIA' ,
modalProps : { media , index , lang } ,
} ) ) ;
2019-01-16 19:47:46 +01:00
} ,
2023-05-11 12:41:55 +02:00
onOpenVideo ( media , lang , options ) {
2023-05-25 15:42:37 +02:00
dispatch ( openModal ( {
modalType : 'VIDEO' ,
modalProps : { media , lang , options } ,
} ) ) ;
2019-01-16 19:47:46 +01:00
} ,
2019-03-26 17:34:02 +01:00
onBlock ( status ) {
const account = status . get ( 'account' ) ;
2019-09-29 21:46:05 +02:00
dispatch ( initBlockModal ( account ) ) ;
2019-01-16 19:47:46 +01:00
} ,
onReport ( status ) {
dispatch ( initReport ( status . get ( 'account' ) , status ) ) ;
} ,
onMute ( account ) {
dispatch ( initMuteModal ( account ) ) ;
} ,
onMuteConversation ( status ) {
if ( status . get ( 'muted' ) ) {
dispatch ( unmuteStatus ( status . get ( 'id' ) ) ) ;
} else {
dispatch ( muteStatus ( status . get ( 'id' ) ) ) ;
}
} ,
onToggleHidden ( status ) {
if ( status . get ( 'hidden' ) ) {
dispatch ( revealStatus ( status . get ( 'id' ) ) ) ;
} else {
dispatch ( hideStatus ( status . get ( 'id' ) ) ) ;
}
} ,
} ) ;
export default injectIntl ( connect ( makeMapStateToProps , mapDispatchToProps ) ( DetailedStatus ) ) ;