import React, {useCallback} from 'react' import {TouchableOpacity, View} from 'react-native' import { AppBskyActorDefs, ModerationCause, ModerationDecision, } from '@atproto/api' import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' import {msg} from '@lingui/macro' import {useLingui} from '@lingui/react' import {useNavigation} from '@react-navigation/native' import {BACK_HITSLOP} from '#/lib/constants' import {makeProfileLink} from '#/lib/routes/links' import {NavigationProp} from '#/lib/routes/types' import {sanitizeDisplayName} from '#/lib/strings/display-names' import {isWeb} from '#/platform/detection' import {Shadow} from '#/state/cache/profile-shadow' import {isConvoActive, useConvo} from '#/state/messages/convo' import {ConvoItem} from '#/state/messages/convo/types' import {PreviewableUserAvatar} from '#/view/com/util/UserAvatar' import {atoms as a, useBreakpoints, useTheme, web} from '#/alf' import {ConvoMenu} from '#/components/dms/ConvoMenu' import {Bell2Off_Filled_Corner0_Rounded as BellStroke} from '#/components/icons/Bell2' import {Link} from '#/components/Link' import {PostAlerts} from '#/components/moderation/PostAlerts' import {Text} from '#/components/Typography' const PFP_SIZE = isWeb ? 40 : 34 export let MessagesListHeader = ({ profile, moderation, }: { profile?: Shadow moderation?: ModerationDecision }): React.ReactNode => { const t = useTheme() const {_} = useLingui() const {gtTablet} = useBreakpoints() const navigation = useNavigation() const blockInfo = React.useMemo(() => { if (!moderation) return const modui = moderation.ui('profileView') const blocks = modui.alerts.filter(alert => alert.type === 'blocking') const listBlocks = blocks.filter(alert => alert.source.type === 'list') const userBlock = blocks.find(alert => alert.source.type === 'user') return { listBlocks, userBlock, } }, [moderation]) const onPressBack = useCallback(() => { if (navigation.canGoBack()) { navigation.goBack() } else { navigation.navigate('Messages', {}) } }, [navigation]) return ( {profile && moderation && blockInfo ? ( ) : ( <> )} ) } MessagesListHeader = React.memo(MessagesListHeader) function HeaderReady({ profile, moderation, blockInfo, }: { profile: Shadow moderation: ModerationDecision blockInfo: { listBlocks: ModerationCause[] userBlock?: ModerationCause } }) { const {_} = useLingui() const t = useTheme() const convoState = useConvo() const isDeletedAccount = profile?.handle === 'missing.invalid' const displayName = isDeletedAccount ? _(msg`Deleted Account`) : sanitizeDisplayName( profile.displayName || profile.handle, moderation.ui('displayName'), ) // @ts-ignore findLast is polyfilled - esb const latestMessageFromOther = convoState.items.findLast( (item: ConvoItem) => item.type === 'message' && item.message.sender.did === profile.did, ) const latestReportableMessage = latestMessageFromOther?.type === 'message' ? latestMessageFromOther.message : undefined return ( {displayName} {!isDeletedAccount && ( @{profile.handle} {convoState.convo?.muted && ( <> {' '} ·{' '} )} )} {isConvoActive(convoState) && ( )} ) }