import React, { useMemo } from 'react'; import { defineMessages, useIntl } from 'react-intl'; import { openModal } from 'soapbox/actions/modals'; import RelativeTimestamp from 'soapbox/components/relative-timestamp'; import { Avatar, HStack, Icon, Stack, Text } from 'soapbox/components/ui'; import VerificationBadge from 'soapbox/components/verification_badge'; import DropdownMenuContainer from 'soapbox/containers/dropdown_menu_container'; import { useAppDispatch } from 'soapbox/hooks'; import { IChat, IChatSilence, useChatActions, useChatSilence } from 'soapbox/queries/chats'; import type { Menu } from 'soapbox/components/dropdown_menu'; const messages = defineMessages({ silenceNotifications: { id: 'chat_settings.silence_notifications', defaultMessage: 'Silence notifications' }, unsilenceNotifications: { id: 'chat_settings.unsilence_notifications', defaultMessage: 'Unsilence notifications' }, 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.' }, leaveHeading: { id: 'chat_settings.leave.heading', defaultMessage: 'Leave Chat' }, leaveConfirm: { id: 'chat_settings.leave.confirm', defaultMessage: 'Leave Chat' }, leaveChat: { id: 'chat_settings.options.leave_chat', defaultMessage: 'Leave Chat' }, }); interface IChatListItemInterface { chat: IChat, onClick: (chat: any) => void, chatSilence?: IChatSilence } const ChatListItem: React.FC = ({ chat, chatSilence, onClick }) => { const dispatch = useAppDispatch(); const intl = useIntl(); const { handleSilence } = useChatSilence(chat); const { deleteChat } = useChatActions(chat?.id as string); const menu = useMemo((): Menu => { const menu: Menu = []; if (chatSilence) { menu.push({ text: intl.formatMessage(messages.unsilenceNotifications), action: (event) => { event.stopPropagation(); handleSilence(); }, icon: require('@tabler/icons/bell.svg'), }); } else { menu.push({ text: intl.formatMessage(messages.silenceNotifications), action: (event) => { event.stopPropagation(); handleSilence(); }, icon: require('@tabler/icons/bell-off.svg'), }); } menu.push({ text: intl.formatMessage(messages.leaveChat), action: (event) => { event.stopPropagation(); dispatch(openModal('CONFIRM', { heading: intl.formatMessage(messages.leaveHeading), message: intl.formatMessage(messages.leaveMessage), confirm: intl.formatMessage(messages.leaveConfirm), confirmationTheme: 'primary', onConfirm: () => deleteChat.mutate(), })); }, icon: require('@tabler/icons/logout.svg'), }); return menu; }, [chatSilence]); return ( // eslint-disable-next-line jsx-a11y/interactive-supports-focus
onClick(chat)} className='group px-2 py-3 w-full flex flex-col rounded-lg hover:bg-gray-100 dark:hover:bg-gray-800 focus:shadow-inset-ring' data-testid='chat' >
{chat.account?.display_name || `@${chat.account.username}`} {chat.account?.verified && }
{chat.last_message?.content && ( )}
{/* TODO: fix nested buttons here */}
{chatSilence ? ( ) : null} {chat.last_message && ( <> {chat.last_message.unread && (
)} )}
); }; export default ChatListItem;