signal-desktop/ts/components/DonationErrorModal.tsx
automated-signal 0a2f341602
Introduce new DonationErrorModal component
Co-authored-by: Scott Nonnenberg <scott@signal.org>
Co-authored-by: ayumi-signal <143036029+ayumi-signal@users.noreply.github.com>
2025-07-15 09:58:17 -07:00

68 lines
1.9 KiB
TypeScript

// Copyright 2025 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import React from 'react';
import type { ReactNode } from 'react';
import { missingCaseError } from '../util/missingCaseError';
import { donationErrorTypeSchema } from '../types/Donations';
import type { LocalizerType } from '../types/Util';
import type { DonationErrorType } from '../types/Donations';
import { Button } from './Button';
import { Modal } from './Modal';
export type PropsType = {
i18n: LocalizerType;
onClose: () => void;
errorType: DonationErrorType;
};
export function DonationErrorModal(props: PropsType): JSX.Element {
const { i18n, onClose } = props;
let title: string;
let body: ReactNode;
switch (props.errorType) {
case donationErrorTypeSchema.Enum.DonationProcessingError: {
title = i18n('icu:Donations__ErrorProcessingDonation');
body = i18n('icu:Donations__ErrorProcessingDonation__Description');
break;
}
case donationErrorTypeSchema.Enum.Failed3dsValidation: {
title = i18n('icu:Donations__Failed3dsValidation');
body = i18n('icu:Donations__Failed3dsValidation__Description');
break;
}
case donationErrorTypeSchema.Enum.GeneralError: {
title = i18n('icu:Donations__GenericError');
body = i18n('icu:Donations__GenericError__Description');
break;
}
case donationErrorTypeSchema.Enum.PaymentDeclined: {
title = i18n('icu:Donations__PaymentMethodDeclined');
body = i18n('icu:Donations__PaymentMethodDeclined__Description');
break;
}
default:
throw missingCaseError(props.errorType);
}
return (
<Modal
i18n={i18n}
modalFooter={
<Button onClick={onClose}>{i18n('icu:Confirmation--confirm')}</Button>
}
hasXButton
moduleClassName="DonationErrorModal"
modalName="DonationErrorModal"
onClose={onClose}
title={title}
>
{body}
</Modal>
);
}