// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import * as React from 'react'; import { Button, ButtonSize, ButtonVariant } from '../Button'; import { SystemMessage } from './SystemMessage'; import type { LocalizerType, ThemeType } from '../../types/Util'; import type { ConversationType } from '../../state/ducks/conversations'; import type { PreferredBadgeSelectorType } from '../../state/selectors/badges'; import { Intl } from '../Intl'; import { ContactName } from './ContactName'; import { GroupV1MigrationDialog } from '../GroupV1MigrationDialog'; import * as log from '../../logging/log'; export type PropsDataType = { areWeInvited: boolean; conversationId: string; droppedMembers: Array; invitedMembers: Array; }; export type PropsHousekeepingType = { getPreferredBadge: PreferredBadgeSelectorType; i18n: LocalizerType; theme: ThemeType; }; export type PropsType = PropsDataType & PropsHousekeepingType; export function GroupV1Migration(props: PropsType): React.ReactElement { const { areWeInvited, conversationId, droppedMembers, getPreferredBadge, i18n, invitedMembers, theme, } = props; const [showingDialog, setShowingDialog] = React.useState(false); const showDialog = React.useCallback(() => { setShowingDialog(true); }, [setShowingDialog]); const dismissDialog = React.useCallback(() => { setShowingDialog(false); }, [setShowingDialog]); return ( <>

{i18n('icu:GroupV1--Migration--was-upgraded')}

{areWeInvited ? ( i18n('icu:GroupV1--Migration--invited--you') ) : ( <> {renderUsers(invitedMembers, i18n, 'invited')} {renderUsers(droppedMembers, i18n, 'removed')} )}

} button={ } /> {showingDialog ? ( log.warn('GroupV1Migration: Modal called migrate()')} onClose={dismissDialog} theme={theme} /> ) : null} ); } function renderUsers( members: Array, i18n: LocalizerType, kind: 'invited' | 'removed' ): React.ReactElement | null { if (!members || members.length === 0) { return null; } if (members.length === 1) { const contact = ; return (

{kind === 'invited' && ( )} {kind === 'removed' && ( )}

); } const count = members.length.toString(); return (

{kind === 'invited' && members.length > 1 && ( )} {kind === 'removed' && members.length > 1 && ( )}

); }