import {msg} from '@lingui/macro' import {useLingui} from '@lingui/react' import {StackActions, useNavigation} from '@react-navigation/native' import {type NavigationProp} from '#/lib/routes/types' import {isNative} from '#/platform/detection' import {useLeaveConvo} from '#/state/queries/messages/leave-conversation' import * as Toast from '#/view/com/util/Toast' import {type DialogOuterProps} from '#/components/Dialog' import * as Prompt from '#/components/Prompt' export function LeaveConvoPrompt({ control, convoId, currentScreen, hasMessages = true, }: { control: DialogOuterProps['control'] convoId: string currentScreen: 'list' | 'conversation' hasMessages?: boolean }) { const {_} = useLingui() const navigation = useNavigation() const {mutate: leaveConvo} = useLeaveConvo(convoId, { onMutate: () => { if (currentScreen === 'conversation') { navigation.dispatch( StackActions.replace('Messages', isNative ? {animation: 'pop'} : {}), ) } }, onError: () => { Toast.show(_(msg`Could not leave chat`), 'xmark') }, }) return ( leaveConvo()} /> ) }