signal-desktop/ts/components/DialogUpdate.tsx

228 lines
6.1 KiB
TypeScript
Raw Normal View History

2023-01-03 19:55:46 +00:00
// Copyright 2020 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import React from 'react';
2021-11-11 22:46:16 +00:00
import { isBeta } from '../util/version';
import { DialogType } from '../types/Dialogs';
import type { LocalizerType } from '../types/Util';
2023-03-20 20:42:00 +00:00
import { PRODUCTION_DOWNLOAD_URL, BETA_DOWNLOAD_URL } from '../types/support';
2021-09-17 22:20:49 +00:00
import { Intl } from './Intl';
import { LeftPaneDialog } from './LeftPaneDialog';
import type { WidthBreakpoint } from './_util';
2024-05-03 21:25:24 +00:00
import { formatFileSize } from '../util/formatFileSize';
export type PropsType = {
containerWidthBreakpoint: WidthBreakpoint;
dialogType: DialogType;
dismissDialog: () => void;
downloadSize?: number;
downloadedSize?: number;
i18n: LocalizerType;
snoozeUpdate: () => void;
startUpdate: () => void;
version?: string;
2021-11-11 22:46:16 +00:00
currentVersion: string;
};
2022-11-18 00:45:19 +00:00
export function DialogUpdate({
containerWidthBreakpoint,
dialogType,
dismissDialog,
downloadSize,
downloadedSize,
i18n,
snoozeUpdate,
startUpdate,
version,
2021-11-11 22:46:16 +00:00
currentVersion,
2022-11-18 00:45:19 +00:00
}: PropsType): JSX.Element | null {
if (dialogType === DialogType.Cannot_Update) {
2021-11-11 22:46:16 +00:00
const url = isBeta(currentVersion)
? BETA_DOWNLOAD_URL
: PRODUCTION_DOWNLOAD_URL;
return (
<LeftPaneDialog
containerWidthBreakpoint={containerWidthBreakpoint}
type="warning"
2023-03-30 00:03:25 +00:00
title={i18n('icu:cannotUpdate')}
>
2021-09-17 22:20:49 +00:00
<span>
<Intl
2022-02-02 21:13:56 +00:00
components={{
retry: (
<button
className="LeftPaneDialog__retry"
key="signal-retry"
onClick={startUpdate}
type="button"
>
2023-03-30 00:03:25 +00:00
{i18n('icu:autoUpdateRetry')}
2022-02-02 21:13:56 +00:00
</button>
),
url: (
<a
key="signal-download"
href={url}
rel="noreferrer"
target="_blank"
>
{url}
</a>
),
support: (
<a
key="signal-support"
href="https://support.signal.org/hc/en-us/requests/new?desktop"
rel="noreferrer"
target="_blank"
>
2023-03-30 00:03:25 +00:00
{i18n('icu:autoUpdateContactSupport')}
2022-02-02 21:13:56 +00:00
</a>
),
}}
2021-09-17 22:20:49 +00:00
i18n={i18n}
2023-03-30 00:03:25 +00:00
id="icu:cannotUpdateDetail"
2021-09-17 22:20:49 +00:00
/>
</span>
</LeftPaneDialog>
);
}
if (dialogType === DialogType.Cannot_Update_Require_Manual) {
const url = isBeta(currentVersion)
? BETA_DOWNLOAD_URL
: PRODUCTION_DOWNLOAD_URL;
return (
<LeftPaneDialog
containerWidthBreakpoint={containerWidthBreakpoint}
type="warning"
2023-03-30 00:03:25 +00:00
title={i18n('icu:cannotUpdate')}
>
<span>
<Intl
components={{
url: (
<a
key="signal-download"
href={url}
rel="noreferrer"
target="_blank"
>
{url}
</a>
),
support: (
<a
key="signal-support"
href="https://support.signal.org/hc/en-us/requests/new?desktop"
rel="noreferrer"
target="_blank"
>
2023-03-30 00:03:25 +00:00
{i18n('icu:autoUpdateContactSupport')}
</a>
),
}}
i18n={i18n}
2023-03-30 00:03:25 +00:00
id="icu:cannotUpdateRequireManualDetail"
/>
</span>
</LeftPaneDialog>
);
}
if (dialogType === DialogType.MacOS_Read_Only) {
return (
2021-09-17 22:20:49 +00:00
<LeftPaneDialog
2023-03-30 00:03:25 +00:00
closeLabel={i18n('icu:close')}
containerWidthBreakpoint={containerWidthBreakpoint}
2021-09-17 22:20:49 +00:00
hasXButton
onClose={dismissDialog}
2023-03-30 00:03:25 +00:00
title={i18n('icu:cannotUpdate')}
2022-02-02 21:13:56 +00:00
type="warning"
2021-09-17 22:20:49 +00:00
>
<span>
<Intl
components={{
app: <strong key="app">Signal.app</strong>,
folder: <strong key="folder">/Applications</strong>,
}}
i18n={i18n}
2023-03-30 00:03:25 +00:00
id="icu:readOnlyVolume"
/>
2021-09-17 22:20:49 +00:00
</span>
</LeftPaneDialog>
);
}
2023-01-18 23:31:10 +00:00
if (dialogType === DialogType.UnsupportedOS) {
// Displayed as UnsupportedOSDialog in LeftPane
return null;
}
2021-09-17 22:20:49 +00:00
const versionTitle = version
2023-03-30 00:03:25 +00:00
? i18n('icu:DialogUpdate--version-available', {
2023-03-27 23:37:39 +00:00
version,
})
2021-09-17 22:20:49 +00:00
: undefined;
if (dialogType === DialogType.Downloading) {
const width = Math.ceil(
((downloadedSize || 1) / (downloadSize || 1)) * 100
);
2021-09-17 22:20:49 +00:00
return (
<LeftPaneDialog
containerWidthBreakpoint={containerWidthBreakpoint}
icon="update"
2023-03-15 16:57:27 +00:00
title={i18n('icu:DialogUpdate__downloading')}
hoverText={versionTitle}
>
2021-09-17 22:20:49 +00:00
<div className="LeftPaneDialog__progress--container">
<div
className="LeftPaneDialog__progress--bar"
style={{ transform: `translateX(${width - 100}%)` }}
2021-09-17 22:20:49 +00:00
/>
</div>
</LeftPaneDialog>
);
}
2023-03-30 00:03:25 +00:00
let title = i18n('icu:autoUpdateNewVersionTitle');
2023-03-15 16:57:27 +00:00
if (
downloadSize &&
(dialogType === DialogType.DownloadReady ||
dialogType === DialogType.FullDownloadReady)
) {
2024-05-03 21:25:24 +00:00
title += ` (${formatFileSize(downloadSize)})`;
2023-03-15 16:57:27 +00:00
}
2023-03-30 00:03:25 +00:00
let clickLabel = i18n('icu:autoUpdateNewVersionMessage');
let type: 'warning' | undefined;
2021-09-17 22:20:49 +00:00
if (dialogType === DialogType.DownloadReady) {
2023-03-30 00:03:25 +00:00
clickLabel = i18n('icu:downloadNewVersionMessage');
} else if (dialogType === DialogType.FullDownloadReady) {
2023-03-30 00:03:25 +00:00
clickLabel = i18n('icu:downloadFullNewVersionMessage');
type = 'warning';
2023-03-15 16:57:27 +00:00
} else if (dialogType === DialogType.DownloadedUpdate) {
title = i18n('icu:DialogUpdate__downloaded');
2021-09-17 22:20:49 +00:00
}
return (
2021-09-17 22:20:49 +00:00
<LeftPaneDialog
containerWidthBreakpoint={containerWidthBreakpoint}
2021-09-17 22:20:49 +00:00
icon="update"
type={type}
2021-09-17 22:20:49 +00:00
title={title}
hoverText={versionTitle}
hasAction
onClick={startUpdate}
clickLabel={clickLabel}
hasXButton
onClose={snoozeUpdate}
2023-03-30 00:03:25 +00:00
closeLabel={i18n('icu:autoUpdateIgnoreButtonLabel')}
2021-09-17 22:20:49 +00:00
/>
);
2022-11-18 00:45:19 +00:00
}