import React, {useCallback} from 'react' import {Keyboard, Pressable, View} from 'react-native' import { AppBskyActorDefs, ChatBskyConvoDefs, ModerationCause, } from '@atproto/api' import {msg, Trans} from '@lingui/macro' import {useLingui} from '@lingui/react' import {useNavigation} from '@react-navigation/native' import {NavigationProp} from '#/lib/routes/types' import {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 {atoms as a, useTheme, ViewStyleProp} from '#/alf' import {BlockedByListDialog} from '#/components/dms/BlockedByListDialog' import {LeaveConvoPrompt} from '#/components/dms/LeaveConvoPrompt' import {ReportConversationPrompt} from '#/components/dms/ReportConversationPrompt' import {ArrowBoxLeft_Stroke2_Corner0_Rounded as ArrowBoxLeft} from '#/components/icons/ArrowBoxLeft' 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 {Bubble_Stroke2_Corner2_Rounded as Bubble} from '../icons/Bubble' let ConvoMenu = ({ convo: initialConvo, profile, control, currentScreen, showMarkAsRead, hideTrigger, blockInfo, style, }: { convo: ChatBskyConvoDefs.ConvoView profile: Shadow control?: Menu.MenuControlProps currentScreen: 'list' | 'conversation' showMarkAsRead?: boolean hideTrigger?: boolean blockInfo: { listBlocks: ModerationCause[] userBlock?: ModerationCause } style?: ViewStyleProp['style'] }): React.ReactNode => { const navigation = useNavigation() const {_} = useLingui() const t = useTheme() const leaveConvoControl = Prompt.usePromptControl() const reportControl = Prompt.usePromptControl() const blockedByListControl = Prompt.usePromptControl() const {mutate: markAsRead} = useMarkAsReadMutation() const {listBlocks, userBlock} = blockInfo const isBlocking = userBlock || !!listBlocks.length const isDeletedAccount = profile.handle === 'missing.invalid' const {data: convo} = useConvoQuery(initialConvo) const onNavigateToProfile = useCallback(() => { navigation.navigate('Profile', {name: profile.did}) }, [navigation, profile.did]) const {mutate: muteConvo} = useMuteConvo(convo?.id, { onSuccess: data => { if (data.convo.muted) { Toast.show(_(msg`Chat muted`)) } else { Toast.show(_(msg`Chat unmuted`)) } }, 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 ( <> {!hideTrigger && ( {({props, state}) => ( { Keyboard.dismiss() // eslint-disable-next-line react/prop-types -- eslint is confused by the name `props` props.onPress() }} style={[ a.p_sm, a.rounded_full, (state.hovered || state.pressed) && t.atoms.bg_contrast_25, // make sure pfp is in the middle {marginLeft: -10}, ]}> )} )} {isDeletedAccount ? ( leaveConvoControl.open()}> Leave conversation ) : ( {showMarkAsRead && ( markAsRead({ convoId: convo?.id, }) }> 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 )} ) } ConvoMenu = React.memo(ConvoMenu) export {ConvoMenu}