signal-desktop/ts/components/InstallScreen.tsx
2024-09-04 12:56:13 +10:00

65 lines
2.4 KiB
TypeScript

// Copyright 2021 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import type { ComponentProps, ReactElement } from 'react';
import React from 'react';
import { missingCaseError } from '../util/missingCaseError';
import { InstallScreenStep } from '../types/InstallScreen';
import { InstallScreenErrorStep } from './installScreen/InstallScreenErrorStep';
import { InstallScreenChoosingDeviceNameStep } from './installScreen/InstallScreenChoosingDeviceNameStep';
import { InstallScreenLinkInProgressStep } from './installScreen/InstallScreenLinkInProgressStep';
import { InstallScreenQrCodeNotScannedStep } from './installScreen/InstallScreenQrCodeNotScannedStep';
import { InstallScreenBackupImportStep } from './installScreen/InstallScreenBackupImportStep';
// We can't always use destructuring assignment because of the complexity of this props
// type.
type PropsType =
| {
step: InstallScreenStep.QrCodeNotScanned;
screenSpecificProps: ComponentProps<
typeof InstallScreenQrCodeNotScannedStep
>;
}
| {
step: InstallScreenStep.ChoosingDeviceName;
screenSpecificProps: ComponentProps<
typeof InstallScreenChoosingDeviceNameStep
>;
}
| {
step: InstallScreenStep.LinkInProgress;
screenSpecificProps: ComponentProps<
typeof InstallScreenLinkInProgressStep
>;
}
| {
step: InstallScreenStep.BackupImport;
screenSpecificProps: ComponentProps<typeof InstallScreenBackupImportStep>;
}
| {
step: InstallScreenStep.Error;
screenSpecificProps: ComponentProps<typeof InstallScreenErrorStep>;
};
export function InstallScreen(props: Readonly<PropsType>): ReactElement {
switch (props.step) {
case InstallScreenStep.Error:
return <InstallScreenErrorStep {...props.screenSpecificProps} />;
case InstallScreenStep.QrCodeNotScanned:
return (
<InstallScreenQrCodeNotScannedStep {...props.screenSpecificProps} />
);
case InstallScreenStep.ChoosingDeviceName:
return (
<InstallScreenChoosingDeviceNameStep {...props.screenSpecificProps} />
);
case InstallScreenStep.LinkInProgress:
return <InstallScreenLinkInProgressStep {...props.screenSpecificProps} />;
case InstallScreenStep.BackupImport:
return <InstallScreenBackupImportStep {...props.screenSpecificProps} />;
default:
throw missingCaseError(props);
}
}