// Copyright 2018-2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import type { EmbeddedContactType, Email, Phone, PostalAddress, } from '../../types/EmbeddedContact'; import { AddressType, ContactFormType } from '../../types/EmbeddedContact'; import { missingCaseError } from '../../util/missingCaseError'; import { renderAvatar, renderContactShorthand, renderName, } from './_contactUtil'; import type { LocalizerType } from '../../types/Util'; export type Props = { contact: EmbeddedContactType; hasSignalAccount: boolean; i18n: LocalizerType; onSendMessage: () => void; }; function getLabelForEmail(method: Email, i18n: LocalizerType): string { switch (method.type) { case ContactFormType.CUSTOM: return method.label || i18n('email'); case ContactFormType.HOME: return i18n('home'); case ContactFormType.MOBILE: return i18n('mobile'); case ContactFormType.WORK: return i18n('work'); default: throw missingCaseError(method.type); } } function getLabelForPhone(method: Phone, i18n: LocalizerType): string { switch (method.type) { case ContactFormType.CUSTOM: return method.label || i18n('phone'); case ContactFormType.HOME: return i18n('home'); case ContactFormType.MOBILE: return i18n('mobile'); case ContactFormType.WORK: return i18n('work'); default: throw missingCaseError(method.type); } } function getLabelForAddress( address: PostalAddress, i18n: LocalizerType ): string { switch (address.type) { case AddressType.CUSTOM: return address.label || i18n('address'); case AddressType.HOME: return i18n('home'); case AddressType.WORK: return i18n('work'); default: throw missingCaseError(address.type); } } export class ContactDetail extends React.Component { public renderSendMessage({ hasSignalAccount, i18n, onSendMessage, }: { hasSignalAccount: boolean; i18n: (key: string, values?: Array) => string; onSendMessage: () => void; }): JSX.Element | null { if (!hasSignalAccount) { return null; } // We don't want the overall click handler for this element to fire, so we stop // propagation before handing control to the caller's callback. const onClick = (e: React.MouseEvent): void => { e.stopPropagation(); onSendMessage(); }; return ( ); } public renderEmail( items: Array | undefined, i18n: LocalizerType ): Array | undefined { if (!items || items.length === 0) { return undefined; } return items.map((item: Email) => { return (
{getLabelForEmail(item, i18n)}
{item.value}
); }); } public renderPhone( items: Array | undefined, i18n: LocalizerType ): Array | null | undefined { if (!items || items.length === 0) { return undefined; } return items.map((item: Phone) => { return (
{getLabelForPhone(item, i18n)}
{item.value}
); }); } public renderAddressLine(value: string | undefined): JSX.Element | undefined { if (!value) { return undefined; } return
{value}
; } public renderPOBox( poBox: string | undefined, i18n: LocalizerType ): JSX.Element | null { if (!poBox) { return null; } return (
{i18n('poBox')} {poBox}
); } public renderAddressLineTwo(address: PostalAddress): JSX.Element | null { if (address.city || address.region || address.postcode) { return (
{address.city} {address.region} {address.postcode}
); } return null; } public renderAddresses( addresses: Array | undefined, i18n: LocalizerType ): Array | undefined { if (!addresses || addresses.length === 0) { return undefined; } return addresses.map((address: PostalAddress, index: number) => { return ( // eslint-disable-next-line react/no-array-index-key
{getLabelForAddress(address, i18n)}
{this.renderAddressLine(address.street)} {this.renderPOBox(address.pobox, i18n)} {this.renderAddressLine(address.neighborhood)} {this.renderAddressLineTwo(address)} {this.renderAddressLine(address.country)}
); }); } public override render(): JSX.Element { const { contact, hasSignalAccount, i18n, onSendMessage } = this.props; const isIncoming = false; const module = 'contact-detail'; return (
{renderAvatar({ contact, i18n, size: 80 })}
{renderName({ contact, isIncoming, module })} {renderContactShorthand({ contact, isIncoming, module })} {this.renderSendMessage({ hasSignalAccount, i18n, onSendMessage })} {this.renderPhone(contact.number, i18n)} {this.renderEmail(contact.email, i18n)} {this.renderAddresses(contact.address, i18n)}
); } }