2022-10-25 05:23:33 -07:00
import React from 'react' ;
2022-09-13 13:33:34 -07:00
import { defineMessages , useIntl } from 'react-intl' ;
2022-08-17 06:58:46 -07:00
2022-10-25 08:40:14 -07:00
import { blockAccount , unblockAccount } from 'soapbox/actions/accounts' ;
2022-08-17 06:58:46 -07:00
import { openModal } from 'soapbox/actions/modals' ;
2022-10-26 10:08:02 -07:00
import List , { ListItem } from 'soapbox/components/list' ;
2022-10-26 10:28:50 -07:00
import { Avatar , HStack , Icon , Select , Stack , Text } from 'soapbox/components/ui' ;
2022-11-02 12:28:16 -07:00
import { ChatWidgetScreens , useChatContext } from 'soapbox/contexts/chat-context' ;
2022-10-25 08:40:14 -07:00
import { useAppDispatch , useAppSelector } from 'soapbox/hooks' ;
2022-10-26 10:28:50 -07:00
import { messageExpirationOptions , MessageExpirationValues , useChatActions } from 'soapbox/queries/chats' ;
import { secondsToDays } from 'soapbox/utils/numbers' ;
2022-08-17 06:58:46 -07:00
import ChatPaneHeader from './chat-pane-header' ;
2022-09-13 13:33:34 -07:00
const messages = defineMessages ( {
blockMessage : { id : 'chat_settings.block.message' , defaultMessage : 'Blocking will prevent this profile from direct messaging you and viewing your content. You can unblock later.' } ,
blockHeading : { id : 'chat_settings.block.heading' , defaultMessage : 'Block @{acct}' } ,
blockConfirm : { id : 'chat_settings.block.confirm' , defaultMessage : 'Block' } ,
2022-10-31 12:51:51 -07:00
unblockMessage : { id : 'chat_settings.unblock.message' , defaultMessage : 'Unblocking will allow this profile to direct message you and view your content.' } ,
2022-10-25 08:40:14 -07:00
unblockHeading : { id : 'chat_settings.unblock.heading' , defaultMessage : 'Unblock @{acct}' } ,
unblockConfirm : { id : 'chat_settings.unblock.confirm' , defaultMessage : 'Unblock' } ,
2022-09-27 07:18:12 -07:00
leaveMessage : { id : 'chat_settings.leave.message' , defaultMessage : 'Are you sure you want to leave this chat? Messages will be deleted for you and this chat will be removed from your inbox.' } ,
2022-09-13 13:33:34 -07:00
leaveHeading : { id : 'chat_settings.leave.heading' , defaultMessage : 'Leave Chat' } ,
leaveConfirm : { id : 'chat_settings.leave.confirm' , defaultMessage : 'Leave Chat' } ,
title : { id : 'chat_settings.title' , defaultMessage : 'Chat Details' } ,
blockUser : { id : 'chat_settings.options.block_user' , defaultMessage : 'Block @{acct}' } ,
2022-10-25 08:40:14 -07:00
unblockUser : { id : 'chat_settings.options.unblock_user' , defaultMessage : 'Unblock @{acct}' } ,
2022-09-13 13:33:34 -07:00
leaveChat : { id : 'chat_settings.options.leave_chat' , defaultMessage : 'Leave Chat' } ,
2022-10-26 10:08:02 -07:00
autoDeleteLabel : { id : 'chat_settings.auto_delete.label' , defaultMessage : 'Auto-delete messages' } ,
2022-10-26 10:28:50 -07:00
autoDeleteDays : { id : 'chat_settings.auto_delete.days' , defaultMessage : '{day} days' } ,
2022-09-13 13:33:34 -07:00
} ) ;
2022-08-17 06:58:46 -07:00
const ChatSettings = ( ) = > {
const dispatch = useAppDispatch ( ) ;
2022-09-13 13:33:34 -07:00
const intl = useIntl ( ) ;
2022-11-02 12:28:16 -07:00
const { chat , changeScreen , toggleChatPane } = useChatContext ( ) ;
2022-10-26 10:08:02 -07:00
const { deleteChat , updateChat } = useChatActions ( chat ? . id as string ) ;
const handleUpdateChat = ( value : MessageExpirationValues ) = > updateChat . mutate ( { message_expiration : value } ) ;
2022-08-17 06:58:46 -07:00
2022-10-25 08:40:14 -07:00
const isBlocking = useAppSelector ( ( state ) = > state . getIn ( [ 'relationships' , chat ? . account ? . id , 'blocking' ] ) ) ;
2022-11-02 12:28:16 -07:00
const closeSettings = ( ) = > {
changeScreen ( ChatWidgetScreens . CHAT , chat ? . id ) ;
} ;
2022-08-17 06:58:46 -07:00
const minimizeChatPane = ( ) = > {
closeSettings ( ) ;
toggleChatPane ( ) ;
} ;
const handleBlockUser = ( ) = > {
dispatch ( openModal ( 'CONFIRM' , {
2022-09-13 13:33:34 -07:00
heading : intl.formatMessage ( messages . blockHeading , { acct : chat?.account.acct } ) ,
message : intl.formatMessage ( messages . blockMessage ) ,
confirm : intl.formatMessage ( messages . blockConfirm ) ,
2022-08-17 06:58:46 -07:00
confirmationTheme : 'primary' ,
2022-09-08 09:47:19 -07:00
onConfirm : ( ) = > dispatch ( blockAccount ( chat ? . account . id as string ) ) ,
2022-08-17 06:58:46 -07:00
} ) ) ;
} ;
2022-10-25 08:40:14 -07:00
const handleUnblockUser = ( ) = > {
dispatch ( openModal ( 'CONFIRM' , {
heading : intl.formatMessage ( messages . unblockHeading , { acct : chat?.account.acct } ) ,
message : intl.formatMessage ( messages . unblockMessage ) ,
confirm : intl.formatMessage ( messages . unblockConfirm ) ,
confirmationTheme : 'primary' ,
onConfirm : ( ) = > dispatch ( unblockAccount ( chat ? . account . id as string ) ) ,
} ) ) ;
} ;
2022-08-17 06:58:46 -07:00
const handleLeaveChat = ( ) = > {
dispatch ( openModal ( 'CONFIRM' , {
2022-09-13 13:33:34 -07:00
heading : intl.formatMessage ( messages . leaveHeading ) ,
message : intl.formatMessage ( messages . leaveMessage ) ,
confirm : intl.formatMessage ( messages . leaveConfirm ) ,
2022-08-17 06:58:46 -07:00
confirmationTheme : 'primary' ,
2022-09-13 13:33:34 -07:00
onConfirm : ( ) = > deleteChat . mutate ( ) ,
2022-08-17 06:58:46 -07:00
} ) ) ;
} ;
if ( ! chat ) {
return null ;
}
return (
< >
< ChatPaneHeader
isOpen
isToggleable = { false }
onToggle = { minimizeChatPane }
title = {
< HStack alignItems = 'center' space = { 2 } >
< button onClick = { closeSettings } >
< Icon
src = { require ( '@tabler/icons/arrow-left.svg' ) }
className = 'h-6 w-6 text-gray-600 dark:text-gray-400'
/ >
< / button >
< Text weight = 'semibold' >
2022-09-13 13:33:34 -07:00
{ intl . formatMessage ( messages . title ) }
2022-08-17 06:58:46 -07:00
< / Text >
< / HStack >
}
/ >
< Stack space = { 4 } className = 'w-5/6 mx-auto' >
2022-10-17 05:34:19 -07:00
< HStack alignItems = 'center' space = { 3 } >
< Avatar src = { chat . account . avatar_static } size = { 50 } / >
2022-08-17 06:58:46 -07:00
< Stack >
2022-10-17 05:34:19 -07:00
< Text weight = 'semibold' > { chat . account . display_name } < / Text >
< Text size = 'sm' theme = 'primary' > @ { chat . account . acct } < / Text >
2022-08-17 06:58:46 -07:00
< / Stack >
2022-10-17 05:34:19 -07:00
< / HStack >
2022-08-17 06:58:46 -07:00
2022-10-26 10:08:02 -07:00
< List >
2022-10-26 10:28:50 -07:00
< ListItem label = { intl . formatMessage ( messages . autoDeleteLabel ) } >
< Select defaultValue = { chat . message_expiration } onChange = { ( event ) = > handleUpdateChat ( Number ( event . target . value ) ) } >
{ messageExpirationOptions . map ( ( duration ) = > {
const inDays = secondsToDays ( duration ) ;
return (
< option key = { duration } value = { duration } >
{ intl . formatMessage ( messages . autoDeleteDays , { day : inDays } ) }
< / option >
) ;
} ) }
< / Select >
< / ListItem >
2022-10-26 10:08:02 -07:00
< / List >
2022-08-17 06:58:46 -07:00
< Stack space = { 5 } >
2022-10-25 08:40:14 -07:00
< button onClick = { isBlocking ? handleUnblockUser : handleBlockUser } className = 'w-full flex items-center space-x-2 font-bold text-sm text-primary-600 dark:text-accent-blue' >
2022-10-05 12:25:56 -07:00
< Icon src = { require ( '@tabler/icons/ban.svg' ) } className = 'w-5 h-5' / >
2022-10-25 08:40:14 -07:00
< span > { intl . formatMessage ( isBlocking ? messages.unblockUser : messages.blockUser , { acct : chat.account.acct } ) } < / span >
2022-08-17 06:58:46 -07:00
< / button >
< button onClick = { handleLeaveChat } className = 'w-full flex items-center space-x-2 font-bold text-sm text-danger-600' >
2022-10-05 12:25:56 -07:00
< Icon src = { require ( '@tabler/icons/logout.svg' ) } className = 'w-5 h-5' / >
2022-09-13 13:33:34 -07:00
< span > { intl . formatMessage ( messages . leaveChat ) } < / span >
2022-08-17 06:58:46 -07:00
< / button >
< / Stack >
< / Stack >
< / >
) ;
} ;
export default ChatSettings ;