2023-01-18 23:31:10 +00:00
|
|
|
// Copyright 2023 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
import React from 'react';
|
|
|
|
import moment from 'moment';
|
|
|
|
import type { FormatXMLElementFn } from 'intl-messageformat';
|
|
|
|
|
|
|
|
import type { LocalizerType } from '../types/Util';
|
2023-03-20 20:42:00 +00:00
|
|
|
import { UNSUPPORTED_OS_URL } from '../types/support';
|
2023-01-18 23:31:10 +00:00
|
|
|
import { missingCaseError } from '../util/missingCaseError';
|
|
|
|
import type { WidthBreakpoint } from './_util';
|
|
|
|
import { Intl } from './Intl';
|
|
|
|
|
|
|
|
import { LeftPaneDialog } from './LeftPaneDialog';
|
|
|
|
|
|
|
|
export type PropsType = {
|
|
|
|
containerWidthBreakpoint: WidthBreakpoint;
|
|
|
|
expirationTimestamp: number;
|
|
|
|
i18n: LocalizerType;
|
|
|
|
type: 'warning' | 'error';
|
|
|
|
OS: string;
|
|
|
|
};
|
|
|
|
|
|
|
|
export function UnsupportedOSDialog({
|
|
|
|
containerWidthBreakpoint,
|
|
|
|
expirationTimestamp,
|
|
|
|
i18n,
|
|
|
|
type,
|
|
|
|
OS,
|
|
|
|
}: PropsType): JSX.Element | null {
|
|
|
|
const learnMoreLink: FormatXMLElementFn<JSX.Element | string> = children => (
|
2023-03-20 20:42:00 +00:00
|
|
|
<a
|
|
|
|
key="signal-support"
|
|
|
|
href={UNSUPPORTED_OS_URL}
|
|
|
|
rel="noreferrer"
|
|
|
|
target="_blank"
|
|
|
|
>
|
2023-01-18 23:31:10 +00:00
|
|
|
{children}
|
|
|
|
</a>
|
|
|
|
);
|
|
|
|
|
|
|
|
let body: JSX.Element;
|
|
|
|
if (type === 'error') {
|
|
|
|
body = (
|
|
|
|
<Intl
|
|
|
|
id="icu:UnsupportedOSErrorDialog__body"
|
|
|
|
i18n={i18n}
|
|
|
|
components={{
|
|
|
|
OS,
|
|
|
|
learnMoreLink,
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
} else if (type === 'warning') {
|
|
|
|
body = (
|
|
|
|
<Intl
|
|
|
|
id="icu:UnsupportedOSWarningDialog__body"
|
|
|
|
i18n={i18n}
|
|
|
|
components={{
|
|
|
|
OS,
|
|
|
|
expirationDate: moment(expirationTimestamp).format('ll'),
|
|
|
|
learnMoreLink,
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
throw missingCaseError(type);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<LeftPaneDialog
|
|
|
|
containerWidthBreakpoint={containerWidthBreakpoint}
|
|
|
|
type={type}
|
|
|
|
>
|
|
|
|
<span>{body}</span>
|
|
|
|
</LeftPaneDialog>
|
|
|
|
);
|
|
|
|
}
|