// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import type { ReactElement } from 'react'; import React from 'react'; import type { LocalizerType } from '../../types/Util'; import { missingCaseError } from '../../util/missingCaseError'; import { openLinkInWebBrowser } from '../../util/openLinkInWebBrowser'; import { Button, ButtonVariant } from '../Button'; import { TitlebarDragArea } from '../TitlebarDragArea'; import { InstallScreenSignalLogo } from './InstallScreenSignalLogo'; import { LINK_SIGNAL_DESKTOP } from '../../types/support'; export enum InstallError { TooManyDevices, TooOld, ConnectionFailed, QRCodeFailed, } export type Props = Readonly<{ error: InstallError; i18n: LocalizerType; quit: () => unknown; tryAgain: () => unknown; }>; export function InstallScreenErrorStep({ error, i18n, quit, tryAgain, }: Props): ReactElement { let errorMessage: string; let buttonText = i18n('icu:installTryAgain'); let onClickButton = () => tryAgain(); let shouldShowQuitButton = false; switch (error) { case InstallError.TooManyDevices: errorMessage = i18n('icu:installTooManyDevices'); break; case InstallError.TooOld: errorMessage = i18n('icu:installTooOld'); buttonText = i18n('icu:upgrade'); onClickButton = () => { openLinkInWebBrowser('https://signal.org/download'); }; shouldShowQuitButton = true; break; case InstallError.ConnectionFailed: errorMessage = i18n('icu:installConnectionFailed'); break; case InstallError.QRCodeFailed: buttonText = i18n('icu:Install__learn-more'); errorMessage = i18n('icu:installUnknownError'); onClickButton = () => { openLinkInWebBrowser(LINK_SIGNAL_DESKTOP); }; shouldShowQuitButton = true; break; default: throw missingCaseError(error); } return (

{i18n('icu:installErrorHeader')}

{errorMessage}

{shouldShowQuitButton && ( )}
); }