// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import { Button, ButtonVariant } from './Button'; import { QrCode } from './QrCode'; import type { ConversationType } from '../state/ducks/conversations'; import { I18n } from './I18n'; import { Emojify } from './conversation/Emojify'; import type { LocalizerType } from '../types/Util'; import type { SafetyNumberType } from '../types/safetyNumber'; import { SAFETY_NUMBER_URL } from '../types/support'; export type PropsType = { contact: ConversationType; generateSafetyNumber: (contact: ConversationType) => void; i18n: LocalizerType; onClose: () => void; safetyNumber: SafetyNumberType | null; toggleVerified: (contact: ConversationType) => void; verificationDisabled: boolean | null; }; export function SafetyNumberViewer({ contact, generateSafetyNumber, i18n, onClose, safetyNumber, toggleVerified, verificationDisabled, }: PropsType): JSX.Element | null { React.useEffect(() => { if (!contact) { return; } generateSafetyNumber(contact); }, [contact, generateSafetyNumber]); // Keyboard navigation if (!contact) { return null; } if (!safetyNumber) { return (
{i18n('icu:cannotGenerateSafetyNumber')}
); } const boldName = ( ); const { isVerified } = contact; const verifyButtonText = isVerified ? i18n('icu:SafetyNumberViewer__clearVerification') : i18n('icu:SafetyNumberViewer__markAsVerified'); const numberBlocks = safetyNumber.numberBlocks.join(' '); const safetyNumberCard = (
{numberBlocks}
); return (
{safetyNumberCard}

); }