// Copyright 2018 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import type { ReactElement } from 'react'; import React from 'react'; import classNames from 'classnames'; import { TypingAnimation } from './TypingAnimation'; import { Avatar } from '../Avatar'; import type { LocalizerType, ThemeType } from '../../types/Util'; import type { ConversationType } from '../../state/ducks/conversations'; import type { BadgeType } from '../../badges/types'; export type Props = Pick< ConversationType, | 'acceptedMessageRequest' | 'avatarPath' | 'color' | 'isMe' | 'phoneNumber' | 'profileName' | 'sharedGroupNames' | 'title' > & { badge: undefined | BadgeType; conversationType: 'group' | 'direct'; i18n: LocalizerType; theme: ThemeType; }; export function TypingBubble({ acceptedMessageRequest, avatarPath, badge, color, conversationType, i18n, isMe, phoneNumber, profileName, sharedGroupNames, theme, title, }: Props): ReactElement { const isGroup = conversationType === 'group'; return (