// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import type { ReactElement } from 'react'; import React, { useCallback, useState } from 'react'; import { Button, ButtonSize, ButtonVariant } from '../Button'; import { SystemMessage } from './SystemMessage'; import type { ConversationType } from '../../state/ducks/conversations'; import type { LocalizerType } from '../../types/Util'; import { I18n } from '../I18n'; import { DeliveryIssueDialog } from './DeliveryIssueDialog'; import { UserText } from '../UserText'; export type PropsDataType = { sender?: ConversationType; inGroup: boolean; }; type PropsHousekeepingType = { i18n: LocalizerType; }; export type PropsType = PropsDataType & PropsHousekeepingType; export function DeliveryIssueNotification( props: PropsType ): ReactElement | null { const { i18n, inGroup, sender } = props; const [isDialogOpen, setIsDialogOpen] = useState(false); const openDialog = useCallback(() => { setIsDialogOpen(true); }, [setIsDialogOpen]); const closeDialog = useCallback(() => { setIsDialogOpen(false); }, [setIsDialogOpen]); if (!sender) { return null; } return ( <> , }} i18n={i18n} /> } icon="info" button={ } /> {isDialogOpen ? ( ) : null} ); }