aboutsummaryrefslogtreecommitdiffstats
path: root/packages/renderer/src/components/errorPage/TrustCertificateDialog.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'packages/renderer/src/components/errorPage/TrustCertificateDialog.tsx')
-rw-r--r--packages/renderer/src/components/errorPage/TrustCertificateDialog.tsx57
1 files changed, 57 insertions, 0 deletions
diff --git a/packages/renderer/src/components/errorPage/TrustCertificateDialog.tsx b/packages/renderer/src/components/errorPage/TrustCertificateDialog.tsx
new file mode 100644
index 0000000..630cbe0
--- /dev/null
+++ b/packages/renderer/src/components/errorPage/TrustCertificateDialog.tsx
@@ -0,0 +1,57 @@
1/*
2 * Copyright (C) 2022 Kristóf Marussy <kristof@marussy.com>
3 *
4 * This file is part of Sophie.
5 *
6 * Sophie is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU Affero General Public License as
8 * published by the Free Software Foundation, version 3.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU Affero General Public License for more details.
14 *
15 * You should have received a copy of the GNU Affero General Public License
16 * along with this program. If not, see <https://www.gnu.org/licenses/>.
17 *
18 * SPDX-License-Identifier: AGPL-3.0-only
19 */
20
21import WarningAmberIcon from '@mui/icons-material/WarningAmber';
22import Box from '@mui/material/Box';
23import Button from '@mui/material/Button';
24import Typography from '@mui/material/Typography';
25import React from 'react';
26import { useTranslation } from 'react-i18next';
27
28export default function TrustCertificateDialog({
29 trust,
30 onClick,
31}: {
32 trust: 'pending' | 'rejected' | 'accepted';
33 onClick: () => void;
34}): JSX.Element {
35 const { t } = useTranslation(undefined, {
36 keyPrefix: 'error.certificateError.details',
37 });
38
39 return (
40 <>
41 <Typography mt={2}>
42 <WarningAmberIcon fontSize="inherit" />{' '}
43 <strong>{t('trustWarning')}</strong>
44 </Typography>
45 <Box mt={1}>
46 <Button
47 disabled={trust !== 'pending'}
48 onClick={onClick}
49 color="error"
50 variant="outlined"
51 >
52 {t(`trustButton.${trust}`)}
53 </Button>
54 </Box>
55 </>
56 );
57}