// Copyright 2019 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import classNames from 'classnames'; import { Avatar, AvatarBlur } from '../Avatar'; import { Spinner } from '../Spinner'; import type { LocalizerType } from '../../types/Util'; import { AvatarColors } from '../../types/Colors'; import type { EmbeddedContactType } from '../../types/EmbeddedContact'; import { getName } from '../../types/EmbeddedContact'; export function renderAvatar({ contact, i18n, size, direction, }: { contact: EmbeddedContactType; i18n: LocalizerType; size: 28 | 52 | 80; direction?: 'outgoing' | 'incoming'; }): JSX.Element { const { avatar } = contact; const avatarUrl = avatar && avatar.avatar && avatar.avatar.path; const pending = avatar && avatar.avatar && avatar.avatar.pending; const title = getName(contact) || ''; const spinnerSvgSize = size < 50 ? 'small' : 'normal'; const spinnerSize = size < 50 ? '24px' : undefined; if (pending) { return (
); } return ( ); } export function renderName({ contact, isIncoming, module, }: { contact: EmbeddedContactType; isIncoming: boolean; module: string; }): JSX.Element { return (
{getName(contact)}
); } export function renderContactShorthand({ contact, isIncoming, module, }: { contact: EmbeddedContactType; isIncoming: boolean; module: string; }): JSX.Element { const { number: phoneNumber, email } = contact; const firstNumber = phoneNumber && phoneNumber[0] && phoneNumber[0].value; const firstEmail = email && email[0] && email[0].value; return (
{firstNumber || firstEmail}
); }