import React, {useCallback} from 'react' import {Keyboard, Pressable, View} from 'react-native' import {AppBskyActorDefs, ChatBskyConvoDefs} 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 { useConvoQuery, useMarkAsReadMutation, } from '#/state/queries/messages/conversation' import {useLeaveConvo} from '#/state/queries/messages/leave-conversation' import {useMuteConvo} from '#/state/queries/messages/mute-conversation' import * as Toast from '#/view/com/util/Toast' import {atoms as a, useTheme} from '#/alf' 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} from '#/components/icons/Person' import {PersonCheck_Stroke2_Corner0_Rounded as PersonCheck} from '#/components/icons/PersonCheck' import {PersonX_Stroke2_Corner0_Rounded as PersonX} from '#/components/icons/PersonX' 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, triggerOpacity, }: { convo: ChatBskyConvoDefs.ConvoView profile: AppBskyActorDefs.ProfileViewBasic onUpdateConvo?: (convo: ChatBskyConvoDefs.ConvoView) => void control?: Menu.MenuControlProps currentScreen: 'list' | 'conversation' showMarkAsRead?: boolean hideTrigger?: boolean triggerOpacity?: number }): React.ReactNode => { const navigation = useNavigation() const {_} = useLingui() const t = useTheme() const leaveConvoControl = Prompt.usePromptControl() const reportControl = Prompt.usePromptControl() const {mutate: markAsRead} = useMarkAsReadMutation() 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`)) }, }) const {mutate: leaveConvo} = useLeaveConvo(convo?.id, { onSuccess: () => { if (currentScreen === 'conversation') { navigation.replace('Messages') } }, onError: () => { Toast.show(_(msg`Could not leave chat`)) }, }) 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}, ]}> )} )} {showMarkAsRead && ( markAsRead({ convoId: convo?.id, }) }> Mark as read )} Go to profile muteConvo({mute: !convo?.muted})}> {convo?.muted ? ( Unmute notifications ) : ( Mute notifications )} {/* TODO(samuel): implement this */} {}} disabled> Block account Report conversation Leave conversation leaveConvo()} /> ) } ConvoMenu = React.memo(ConvoMenu) export {ConvoMenu} function noop() {}