diff --git a/native/components/thread-avatar.react.js b/native/components/thread-avatar.react.js new file mode 100644 --- /dev/null +++ b/native/components/thread-avatar.react.js @@ -0,0 +1,51 @@ +// @flow + +import * as React from 'react'; + +import { + useGetAvatarForThread, + useENSResolvedAvatar, +} from 'lib/shared/avatar-utils.js'; +import { getSingleOtherUser } from 'lib/shared/thread-utils.js'; +import { + threadTypes, + type RawThreadInfo, + type ThreadInfo, +} from 'lib/types/thread-types.js'; + +import Avatar from './avatar.react.js'; +import { useSelector } from '../redux/redux-utils.js'; + +type Props = { + +threadInfo: RawThreadInfo | ThreadInfo, + +size: 'micro' | 'small' | 'large' | 'profile', +}; + +function ThreadAvatar(props: Props): React.Node { + const { threadInfo, size } = props; + + const avatarInfo = useGetAvatarForThread(threadInfo); + + const viewerID = useSelector( + state => state.currentUserInfo && state.currentUserInfo.id, + ); + + let displayUserIDForThread; + if (threadInfo.type === threadTypes.PRIVATE) { + displayUserIDForThread = viewerID; + } else if (threadInfo.type === threadTypes.PERSONAL) { + displayUserIDForThread = getSingleOtherUser(threadInfo, viewerID); + } + + const displayUser = useSelector(state => + displayUserIDForThread + ? state.userStore.userInfos[displayUserIDForThread] + : null, + ); + + const resolvedThreadAvatar = useENSResolvedAvatar(avatarInfo, displayUser); + + return ; +} + +export default ThreadAvatar;