signal-desktop/ts/components/SafetyNumberModal.tsx

59 lines
1.5 KiB
TypeScript
Raw Normal View History

// Copyright 2021 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
2023-11-01 22:55:30 +00:00
import React from 'react';
import { isSafetyNumberNotAvailable } from '../util/isSafetyNumberNotAvailable';
import { Modal } from './Modal';
import type { PropsType as SafetyNumberViewerPropsType } from './SafetyNumberViewer';
import { SafetyNumberViewer } from './SafetyNumberViewer';
import { SafetyNumberNotReady } from './SafetyNumberNotReady';
type PropsType = {
toggleSafetyNumberModal: () => unknown;
2022-03-02 18:24:28 +00:00
} & Omit<SafetyNumberViewerPropsType, 'onClose'>;
2022-11-18 00:45:19 +00:00
export function SafetyNumberModal({
i18n,
toggleSafetyNumberModal,
...safetyNumberViewerProps
2022-11-18 00:45:19 +00:00
}: PropsType): JSX.Element | null {
const { contact } = safetyNumberViewerProps;
let title: string | undefined;
let content: JSX.Element;
let hasXButton = true;
if (isSafetyNumberNotAvailable(contact)) {
content = (
<SafetyNumberNotReady
i18n={i18n}
onClose={() => toggleSafetyNumberModal()}
/>
);
hasXButton = false;
} else {
title = i18n('icu:SafetyNumberModal__title');
content = (
<SafetyNumberViewer
i18n={i18n}
onClose={toggleSafetyNumberModal}
{...safetyNumberViewerProps}
/>
);
}
return (
<Modal
2022-09-27 20:24:21 +00:00
modalName="SafetyNumberModal"
hasXButton={hasXButton}
i18n={i18n}
moduleClassName="module-SafetyNumberViewer__modal"
2022-03-02 18:24:28 +00:00
onClose={toggleSafetyNumberModal}
title={title}
>
{content}
</Modal>
);
2022-11-18 00:45:19 +00:00
}