2020-03-27 13:59:38 -07:00
import React from 'react' ;
2022-01-10 14:01:24 -08:00
import { defineMessages , injectIntl , FormattedMessage } from 'react-intl' ;
2022-01-10 14:17:52 -08:00
import { connect } from 'react-redux' ;
2022-01-10 14:25:06 -08:00
2022-04-27 13:50:35 -07:00
import { blockAccount } from 'soapbox/actions/accounts' ;
import { showAlertForError } from 'soapbox/actions/alerts' ;
2022-01-10 14:01:24 -08:00
import { launchChat } from 'soapbox/actions/chats' ;
2020-03-27 13:59:38 -07:00
import {
replyCompose ,
mentionCompose ,
directCompose ,
2022-04-27 13:50:35 -07:00
} from 'soapbox/actions/compose' ;
2020-03-27 13:59:38 -07:00
import {
reblog ,
favourite ,
unreblog ,
unfavourite ,
2020-08-30 22:09:02 -07:00
bookmark ,
unbookmark ,
2020-03-27 13:59:38 -07:00
pin ,
unpin ,
2022-04-27 13:50:35 -07:00
} from 'soapbox/actions/interactions' ;
import { openModal } from 'soapbox/actions/modals' ;
import { deactivateUserModal , deleteUserModal , deleteStatusModal , toggleStatusSensitivityModal } from 'soapbox/actions/moderation' ;
import { initMuteModal } from 'soapbox/actions/mutes' ;
import { initReport } from 'soapbox/actions/reports' ;
import { getSettings } from 'soapbox/actions/settings' ;
2020-03-27 13:59:38 -07:00
import {
muteStatus ,
unmuteStatus ,
deleteStatus ,
hideStatus ,
revealStatus ,
2022-04-27 13:50:35 -07:00
editStatus ,
} from 'soapbox/actions/statuses' ;
import { makeGetStatus } from 'soapbox/selectors' ;
2022-04-04 13:55:28 -07:00
import DetailedStatus from '../components/detailed-status' ;
2020-03-27 13:59:38 -07:00
const messages = defineMessages ( {
deleteConfirm : { id : 'confirmations.delete.confirm' , defaultMessage : 'Delete' } ,
2022-01-06 07:51:34 -08:00
deleteHeading : { id : 'confirmations.delete.heading' , defaultMessage : 'Delete post' } ,
2020-03-27 13:59:38 -07:00
deleteMessage : { id : 'confirmations.delete.message' , defaultMessage : 'Are you sure you want to delete this post?' } ,
redraftConfirm : { id : 'confirmations.redraft.confirm' , defaultMessage : 'Delete & redraft' } ,
2021-12-30 08:38:57 -08:00
redraftHeading : { id : 'confirmations.redraft.heading' , defaultMessage : 'Delete & redraft' } ,
2020-03-27 13:59:38 -07:00
redraftMessage : { id : 'confirmations.redraft.message' , defaultMessage : 'Are you sure you want to delete this post and re-draft it? Favorites and reposts will be lost, and replies to the original post will be orphaned.' } ,
blockConfirm : { id : 'confirmations.block.confirm' , defaultMessage : 'Block' } ,
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?' } ,
blockAndReport : { id : 'confirmations.block.block_and_report' , defaultMessage : 'Block & Report' } ,
} ) ;
const makeMapStateToProps = ( ) => {
const getStatus = makeGetStatus ( ) ;
const mapStateToProps = ( state , props ) => ( {
status : getStatus ( state , props ) ,
domain : state . getIn ( [ 'meta' , 'domain' ] ) ,
} ) ;
return mapStateToProps ;
} ;
const mapDispatchToProps = ( dispatch , { intl } ) => ( {
2022-06-20 06:46:43 -07:00
onReply ( status ) {
2020-03-27 13:59:38 -07:00
dispatch ( ( _ , getState ) => {
2021-08-03 10:10:42 -07:00
const state = getState ( ) ;
2020-03-27 13:59:38 -07:00
if ( state . getIn ( [ 'compose' , 'text' ] ) . trim ( ) . length !== 0 ) {
dispatch ( openModal ( 'CONFIRM' , {
message : intl . formatMessage ( messages . replyMessage ) ,
confirm : intl . formatMessage ( messages . replyConfirm ) ,
2022-06-20 06:46:43 -07:00
onConfirm : ( ) => dispatch ( replyCompose ( status ) ) ,
2020-03-27 13:59:38 -07:00
} ) ) ;
} else {
2022-06-20 06:46:43 -07:00
dispatch ( replyCompose ( status ) ) ;
2020-03-27 13:59:38 -07:00
}
} ) ;
} ,
2020-04-14 14:47:35 -07:00
onModalReblog ( status ) {
2020-03-27 13:59:38 -07:00
dispatch ( reblog ( status ) ) ;
} ,
2020-04-14 14:47:35 -07:00
onReblog ( status , e ) {
2020-04-21 12:41:13 -07:00
dispatch ( ( _ , getState ) => {
2020-04-28 11:49:39 -07:00
const boostModal = getSettings ( getState ( ) ) . get ( 'boostModal' ) ;
2020-04-21 12:41:13 -07:00
if ( status . get ( 'reblogged' ) ) {
dispatch ( unreblog ( status ) ) ;
2020-03-27 13:59:38 -07:00
} else {
2020-04-21 12:41:13 -07:00
if ( e . shiftKey || ! boostModal ) {
this . onModalReblog ( status ) ;
} else {
dispatch ( openModal ( 'BOOST' , { status , onReblog : this . onModalReblog } ) ) ;
}
2020-03-27 13:59:38 -07:00
}
2020-04-21 12:41:13 -07:00
} ) ;
2020-03-27 13:59:38 -07:00
} ,
2020-08-30 22:09:02 -07:00
onBookmark ( status ) {
if ( status . get ( 'bookmarked' ) ) {
2022-01-27 07:00:05 -08:00
dispatch ( unbookmark ( status ) ) ;
2020-08-30 22:09:02 -07:00
} else {
2022-01-27 07:00:05 -08:00
dispatch ( bookmark ( status ) ) ;
2020-08-30 22:09:02 -07:00
}
} ,
2020-04-14 14:47:35 -07:00
onFavourite ( status ) {
2020-03-27 13:59:38 -07:00
if ( status . get ( 'favourited' ) ) {
dispatch ( unfavourite ( status ) ) ;
} else {
dispatch ( favourite ( status ) ) ;
}
} ,
2020-04-14 14:47:35 -07:00
onPin ( status ) {
2020-03-27 13:59:38 -07:00
if ( status . get ( 'pinned' ) ) {
dispatch ( unpin ( status ) ) ;
} else {
dispatch ( pin ( status ) ) ;
}
} ,
2020-04-14 14:47:35 -07:00
onEmbed ( status ) {
2020-03-27 13:59:38 -07:00
dispatch ( openModal ( 'EMBED' , {
url : status . get ( 'url' ) ,
onError : error => dispatch ( showAlertForError ( error ) ) ,
} ) ) ;
} ,
2022-06-19 12:26:57 -07:00
onDelete ( status , withRedraft = false ) {
2020-04-21 12:41:13 -07:00
dispatch ( ( _ , getState ) => {
2020-04-28 11:49:39 -07:00
const deleteModal = getSettings ( getState ( ) ) . get ( 'deleteModal' ) ;
2020-04-21 12:41:13 -07:00
if ( ! deleteModal ) {
2022-06-19 12:26:57 -07:00
dispatch ( deleteStatus ( status . get ( 'id' ) , withRedraft ) ) ;
2020-04-21 12:41:13 -07:00
} else {
dispatch ( openModal ( 'CONFIRM' , {
2021-12-30 08:38:57 -08:00
icon : withRedraft ? require ( '@tabler/icons/icons/edit.svg' ) : require ( '@tabler/icons/icons/trash.svg' ) ,
heading : intl . formatMessage ( withRedraft ? messages . redraftHeading : messages . deleteHeading ) ,
2020-04-21 12:41:13 -07:00
message : intl . formatMessage ( withRedraft ? messages . redraftMessage : messages . deleteMessage ) ,
confirm : intl . formatMessage ( withRedraft ? messages . redraftConfirm : messages . deleteConfirm ) ,
2022-06-19 12:26:57 -07:00
onConfirm : ( ) => dispatch ( deleteStatus ( status . get ( 'id' ) , withRedraft ) ) ,
2020-04-21 12:41:13 -07:00
} ) ) ;
}
} ) ;
2020-03-27 13:59:38 -07:00
} ,
2022-04-27 13:50:35 -07:00
onEdit ( status ) {
dispatch ( editStatus ( status . get ( 'id' ) ) ) ;
} ,
2022-06-20 06:46:43 -07:00
onDirect ( account ) {
dispatch ( directCompose ( account ) ) ;
2020-03-27 13:59:38 -07:00
} ,
2021-10-13 11:55:02 -07:00
onChat ( account , router ) {
2021-10-14 10:23:51 -07:00
dispatch ( launchChat ( account . get ( 'id' ) , router ) ) ;
2021-10-13 11:55:02 -07:00
} ,
2022-06-20 06:46:43 -07:00
onMention ( account ) {
dispatch ( mentionCompose ( account ) ) ;
2020-03-27 13:59:38 -07:00
} ,
2020-04-14 14:47:35 -07:00
onOpenMedia ( media , index ) {
2020-03-27 13:59:38 -07:00
dispatch ( openModal ( 'MEDIA' , { media , index } ) ) ;
} ,
2020-04-14 14:47:35 -07:00
onOpenVideo ( media , time ) {
2020-03-27 13:59:38 -07:00
dispatch ( openModal ( 'VIDEO' , { media , time } ) ) ;
} ,
2020-04-14 14:47:35 -07:00
onBlock ( status ) {
2020-03-27 13:59:38 -07:00
const account = status . get ( 'account' ) ;
dispatch ( openModal ( 'CONFIRM' , {
2021-12-30 08:38:57 -08:00
icon : require ( '@tabler/icons/icons/ban.svg' ) ,
heading : < FormattedMessage id = 'confirmations.block.heading' defaultMessage = 'Block @{name}' values = { { name : account . get ( 'acct' ) } } / > ,
2020-03-27 13:59:38 -07:00
message : < FormattedMessage id = 'confirmations.block.message' defaultMessage = 'Are you sure you want to block {name}?' values = { { name : < strong > @ { account . get ( 'acct' ) } < /strong> }} / > ,
confirm : intl . formatMessage ( messages . blockConfirm ) ,
onConfirm : ( ) => dispatch ( blockAccount ( account . get ( 'id' ) ) ) ,
secondary : intl . formatMessage ( messages . blockAndReport ) ,
onSecondary : ( ) => {
dispatch ( blockAccount ( account . get ( 'id' ) ) ) ;
dispatch ( initReport ( account , status ) ) ;
} ,
} ) ) ;
} ,
2020-04-14 14:47:35 -07:00
onReport ( status ) {
2020-03-27 13:59:38 -07:00
dispatch ( initReport ( status . get ( 'account' ) , status ) ) ;
} ,
2020-04-14 14:47:35 -07:00
onMute ( account ) {
2020-03-27 13:59:38 -07:00
dispatch ( initMuteModal ( account ) ) ;
} ,
2020-04-14 14:47:35 -07:00
onMuteConversation ( status ) {
2020-03-27 13:59:38 -07:00
if ( status . get ( 'muted' ) ) {
dispatch ( unmuteStatus ( status . get ( 'id' ) ) ) ;
} else {
dispatch ( muteStatus ( status . get ( 'id' ) ) ) ;
}
} ,
2020-04-14 14:47:35 -07:00
onToggleHidden ( status ) {
2020-03-27 13:59:38 -07:00
if ( status . get ( 'hidden' ) ) {
dispatch ( revealStatus ( status . get ( 'id' ) ) ) ;
} else {
dispatch ( hideStatus ( status . get ( 'id' ) ) ) ;
}
} ,
2021-01-18 13:27:35 -08:00
onDeactivateUser ( status ) {
dispatch ( deactivateUserModal ( intl , status . getIn ( [ 'account' , 'id' ] ) ) ) ;
} ,
onDeleteUser ( status ) {
dispatch ( deleteUserModal ( intl , status . getIn ( [ 'account' , 'id' ] ) ) ) ;
} ,
2021-01-18 18:59:07 -08:00
onToggleStatusSensitivity ( status ) {
dispatch ( toggleStatusSensitivityModal ( intl , status . get ( 'id' ) , status . get ( 'sensitive' ) ) ) ;
} ,
2021-01-18 13:57:20 -08:00
onDeleteStatus ( status ) {
dispatch ( deleteStatusModal ( intl , status . get ( 'id' ) ) ) ;
} ,
2022-04-27 13:50:35 -07:00
onOpenCompareHistoryModal ( status ) {
dispatch ( openModal ( 'COMPARE_HISTORY' , {
statusId : status . get ( 'id' ) ,
} ) ) ;
} ,
2020-03-27 13:59:38 -07:00
} ) ;
export default injectIntl ( connect ( makeMapStateToProps , mapDispatchToProps ) ( DetailedStatus ) ) ;