bigbuffet-rw/app/soapbox/features/chats/components/chat-message-list-intro.tsx

123 lines
4.4 KiB
TypeScript
Raw Normal View History

2023-02-06 10:01:03 -08:00
import clsx from 'clsx';
2022-08-17 12:48:04 -07:00
import React from 'react';
2022-09-14 07:35:32 -07:00
import { defineMessages, useIntl } from 'react-intl';
import { useHistory } from 'react-router-dom';
2022-08-17 12:48:04 -07:00
import { openModal } from 'soapbox/actions/modals';
2022-09-30 07:22:55 -07:00
import Link from 'soapbox/components/link';
2022-08-17 12:48:04 -07:00
import { Avatar, Button, HStack, Icon, Stack, Text } from 'soapbox/components/ui';
import { useChatContext } from 'soapbox/contexts/chat-context';
import { useAppDispatch, useFeatures } from 'soapbox/hooks';
2022-09-28 13:20:59 -07:00
import { useChatActions } from 'soapbox/queries/chats';
import { secondsToDays } from 'soapbox/utils/numbers';
2022-08-17 12:48:04 -07:00
2022-09-14 07:35:32 -07:00
const messages = defineMessages({
leaveChatHeading: { id: 'chat_message_list_intro.leave_chat.heading', defaultMessage: 'Leave Chat' },
2022-09-27 07:18:12 -07:00
leaveChatMessage: { id: 'chat_message_list_intro.leave_chat.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-14 07:35:32 -07:00
leaveChatConfirm: { id: 'chat_message_list_intro.leave_chat.confirm', defaultMessage: 'Leave Chat' },
intro: { id: 'chat_message_list_intro.intro', defaultMessage: 'wants to start a chat with you' },
accept: { id: 'chat_message_list_intro.actions.accept', defaultMessage: 'Accept' },
leaveChat: { id: 'chat_message_list_intro.actions.leave_chat', defaultMessage: 'Leave chat' },
report: { id: 'chat_message_list_intro.actions.report', defaultMessage: 'Report' },
messageLifespan: { id: 'chat_message_list_intro.actions.message_lifespan', defaultMessage: 'Messages older than {day, plural, one {# day} other {# days}} are deleted.' },
2022-09-14 07:35:32 -07:00
});
2022-08-17 12:48:04 -07:00
const ChatMessageListIntro = () => {
const dispatch = useAppDispatch();
2022-09-14 07:35:32 -07:00
const intl = useIntl();
const features = useFeatures();
const history = useHistory();
2022-08-17 12:48:04 -07:00
const { chat, isUsingMainChatPage, needsAcceptance } = useChatContext();
2022-09-28 13:20:59 -07:00
const { acceptChat, deleteChat } = useChatActions(chat?.id as string);
2022-08-17 12:48:04 -07:00
const handleLeaveChat = () => {
dispatch(openModal('CONFIRM', {
2022-09-14 07:35:32 -07:00
heading: intl.formatMessage(messages.leaveChatHeading),
message: intl.formatMessage(messages.leaveChatMessage),
confirm: intl.formatMessage(messages.leaveChatConfirm),
2022-08-17 12:48:04 -07:00
confirmationTheme: 'primary',
onConfirm: () => {
deleteChat.mutate(undefined, {
onSuccess() {
if (isUsingMainChatPage) {
history.push('/chats');
}
},
});
},
2022-08-17 12:48:04 -07:00
}));
};
if (!chat || !features.chatAcceptance) {
2022-08-17 12:48:04 -07:00
return null;
}
return (
<Stack
2022-09-12 11:42:15 -07:00
data-testid='chat-message-list-intro'
2022-08-17 12:48:04 -07:00
justifyContent='center'
alignItems='center'
space={4}
className={
2023-02-06 10:01:03 -08:00
clsx({
2022-08-17 12:48:04 -07:00
'w-3/4 mx-auto': needsAcceptance,
2022-10-05 12:25:56 -07:00
'py-6': true, // needs to be padding to prevent Virtuoso bugs
2022-08-17 12:48:04 -07:00
})
}
>
<Stack alignItems='center' space={2}>
2022-11-07 07:04:02 -08:00
<Link to={`/@${chat.account.acct}`}>
2022-09-30 07:22:55 -07:00
<Avatar src={chat.account.avatar_static} size={75} />
</Link>
2022-08-17 12:48:04 -07:00
<Text size='lg' align='center'>
{needsAcceptance ? (
<>
<Text tag='span' weight='semibold'>@{chat.account.acct}</Text>
{' '}
2022-09-14 07:35:32 -07:00
<Text tag='span'>{intl.formatMessage(messages.intro)}</Text>
2022-08-17 12:48:04 -07:00
</>
) : (
2022-11-07 07:04:02 -08:00
<Link to={`/@${chat.account.acct}`}>
2022-09-30 07:22:55 -07:00
<Text tag='span' theme='inherit' weight='semibold'>@{chat.account.acct}</Text>
</Link>
2022-08-17 12:48:04 -07:00
)}
</Text>
</Stack>
{needsAcceptance ? (
<HStack alignItems='center' space={2} className='w-full'>
2022-08-17 12:48:04 -07:00
<Button
theme='primary'
block
2022-09-14 07:35:32 -07:00
onClick={() => acceptChat.mutate()}
2022-08-17 12:48:04 -07:00
disabled={acceptChat.isLoading}
>
2022-09-14 07:35:32 -07:00
{intl.formatMessage(messages.accept)}
2022-08-17 12:48:04 -07:00
</Button>
<Button
theme='danger'
block
onClick={handleLeaveChat}
>
{intl.formatMessage(messages.leaveChat)}
</Button>
</HStack>
2022-08-17 12:48:04 -07:00
) : (
2023-02-01 14:13:42 -08:00
<HStack justifyContent='center' alignItems='center' space={1} className='shrink-0'>
<Icon src={require('@tabler/icons/clock.svg')} className='h-4 w-4 text-gray-600' />
{chat.message_expiration && (
<Text size='sm' theme='muted'>
{intl.formatMessage(messages.messageLifespan, { day: secondsToDays(chat.message_expiration) })}
</Text>
)}
2022-08-17 12:48:04 -07:00
</HStack>
)}
</Stack>
);
};
export default ChatMessageListIntro;