import React, {useCallback} from 'react' import {Keyboard, View} from 'react-native' import {type ChatBskyConvoDefs, type ModerationCause} from '@atproto/api' import {msg, Trans} from '@lingui/macro' import {useLingui} from '@lingui/react' import {useNavigation} from '@react-navigation/native' import {type NavigationProp} from '#/lib/routes/types' import {type Shadow} from '#/state/cache/types' import { useConvoQuery, useMarkAsReadMutation, } from '#/state/queries/messages/conversation' import {useMuteConvo} from '#/state/queries/messages/mute-conversation' import {useProfileBlockMutationQueue} from '#/state/queries/profile' import * as Toast from '#/view/com/util/Toast' import {type ViewStyleProp} from '#/alf' import {atoms as a} from '#/alf' import {Button, ButtonIcon} from '#/components/Button' import {BlockedByListDialog} from '#/components/dms/BlockedByListDialog' import {LeaveConvoPrompt} from '#/components/dms/LeaveConvoPrompt' import {ReportConversationPrompt} from '#/components/dms/ReportConversationPrompt' import {ReportDialog} from '#/components/dms/ReportDialog' import {ArrowBoxLeft_Stroke2_Corner0_Rounded as ArrowBoxLeft} from '#/components/icons/ArrowBoxLeft' import {Bubble_Stroke2_Corner2_Rounded as Bubble} from '#/components/icons/Bubble' import {DotGrid_Stroke2_Corner0_Rounded as DotsHorizontal} from '#/components/icons/DotGrid' import {Flag_Stroke2_Corner0_Rounded as Flag} from '#/components/icons/Flag' import {Mute_Stroke2_Corner0_Rounded as Mute} from '#/components/icons/Mute' import { Person_Stroke2_Corner0_Rounded as Person, PersonCheck_Stroke2_Corner0_Rounded as PersonCheck, PersonX_Stroke2_Corner0_Rounded as PersonX, } from '#/components/icons/Person' import {SpeakerVolumeFull_Stroke2_Corner0_Rounded as Unmute} from '#/components/icons/Speaker' import * as Menu from '#/components/Menu' import * as Prompt from '#/components/Prompt' import type * as bsky from '#/types/bsky' let ConvoMenu = ({ convo, profile, control, currentScreen, showMarkAsRead, hideTrigger, blockInfo, latestReportableMessage, style, }: { convo: ChatBskyConvoDefs.ConvoView profile: Shadow control?: Menu.MenuControlProps currentScreen: 'list' | 'conversation' showMarkAsRead?: boolean hideTrigger?: boolean blockInfo: { listBlocks: ModerationCause[] userBlock?: ModerationCause } latestReportableMessage?: ChatBskyConvoDefs.MessageView style?: ViewStyleProp['style'] }): React.ReactNode => { const {_} = useLingui() const leaveConvoControl = Prompt.usePromptControl() const reportControl = Prompt.usePromptControl() const blockedByListControl = Prompt.usePromptControl() const {listBlocks} = blockInfo return ( <> {!hideTrigger && ( {({props}) => ( )} )} {latestReportableMessage ? ( ) : ( )} ) } ConvoMenu = React.memo(ConvoMenu) function MenuContent({ convo: initialConvo, profile, showMarkAsRead, blockInfo, leaveConvoControl, reportControl, blockedByListControl, }: { convo: ChatBskyConvoDefs.ConvoView profile: Shadow showMarkAsRead?: boolean blockInfo: { listBlocks: ModerationCause[] userBlock?: ModerationCause } leaveConvoControl: Prompt.PromptControlProps reportControl: Prompt.PromptControlProps blockedByListControl: Prompt.PromptControlProps }) { const navigation = useNavigation() const {_} = useLingui() const {mutate: markAsRead} = useMarkAsReadMutation() const {listBlocks, userBlock} = blockInfo const isBlocking = userBlock || !!listBlocks.length const isDeletedAccount = profile.handle === 'missing.invalid' const convoId = initialConvo.id const {data: convo} = useConvoQuery(initialConvo) const onNavigateToProfile = useCallback(() => { navigation.navigate('Profile', {name: profile.did}) }, [navigation, profile.did]) const {mutate: muteConvo} = useMuteConvo(convoId, { onSuccess: data => { if (data.convo.muted) { Toast.show(_(msg({message: 'Chat muted', context: 'toast'}))) } else { Toast.show(_(msg({message: 'Chat unmuted', context: 'toast'}))) } }, onError: () => { Toast.show(_(msg`Could not mute chat`), 'xmark') }, }) const [queueBlock, queueUnblock] = useProfileBlockMutationQueue(profile) const toggleBlock = React.useCallback(() => { if (listBlocks.length) { blockedByListControl.open() return } if (userBlock) { queueUnblock() } else { queueBlock() } }, [userBlock, listBlocks, blockedByListControl, queueBlock, queueUnblock]) return isDeletedAccount ? ( leaveConvoControl.open()}> Leave conversation ) : ( <> {showMarkAsRead && ( markAsRead({convoId})}> Mark as read )} Go to profile muteConvo({mute: !convo?.muted})}> {convo?.muted ? ( Unmute conversation ) : ( Mute conversation )} {isBlocking ? _(msg`Unblock account`) : _(msg`Block account`)} reportControl.open()}> Report conversation leaveConvoControl.open()}> Leave conversation ) } export {ConvoMenu}