// Copyright 2024 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import type { LocalizerType } from '../../types/Util'; import { formatFileSize } from '../../util/formatFileSize'; import { TitlebarDragArea } from '../TitlebarDragArea'; import { ProgressBar } from '../ProgressBar'; import { InstallScreenSignalLogo } from './InstallScreenSignalLogo'; // We can't always use destructuring assignment because of the complexity of this props // type. export type PropsType = Readonly<{ i18n: LocalizerType; currentBytes?: number; totalBytes?: number; }>; export function InstallScreenBackupImportStep({ i18n, currentBytes, totalBytes, }: PropsType): JSX.Element { let percentage = 0; let progress: JSX.Element; if (currentBytes != null && totalBytes != null) { percentage = Math.max(0, Math.min(1, currentBytes / totalBytes)); if (percentage > 0 && percentage <= 0.01) { percentage = 0.01; } else if (percentage >= 0.99 && percentage < 1) { percentage = 0.99; } else { percentage = Math.round(percentage * 100) / 100; } progress = ( <>
{i18n('icu:BackupImportScreen__progressbar-hint', { currentSize: formatFileSize(currentBytes), totalSize: formatFileSize(totalBytes), fractionComplete: percentage, })}
); } else { progress = ( <>
{i18n('icu:BackupImportScreen__progressbar-hint', { currentSize: '', totalSize: '', fractionComplete: 0, })}
); } return (

{i18n('icu:BackupImportScreen__title')}

{progress}
{i18n('icu:BackupImportScreen__description')}
); }