// Copyright 2022 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import formatFileSize from 'filesize'; import type { LocalizerType } from '../types/Util'; import type { PreferredBadgeSelectorType } from '../state/selectors/badges'; import type { StorySendStateType, StoryViewType } from '../types/Stories'; import { Avatar, AvatarSize } from './Avatar'; import { ContactName } from './conversation/ContactName'; import { ContextMenu } from './ContextMenu'; import { Intl } from './Intl'; import { Modal } from './Modal'; import { SendStatus } from '../messages/MessageSendState'; import { Theme } from '../util/theme'; import { ThemeType } from '../types/Util'; import { Time } from './Time'; import { formatDateTimeLong } from '../util/timestamp'; import { groupBy } from '../util/mapUtil'; export type PropsType = { getPreferredBadge: PreferredBadgeSelectorType; i18n: LocalizerType; onClose: () => unknown; sender: StoryViewType['sender']; sendState?: Array; size?: number; timestamp: number; }; const contactSortCollator = new window.Intl.Collator(); function getI18nKey(sendStatus: SendStatus | undefined): string { if (sendStatus === SendStatus.Failed) { return 'MessageDetailsHeader--Failed'; } if (sendStatus === SendStatus.Viewed) { return 'MessageDetailsHeader--Viewed'; } if (sendStatus === SendStatus.Read) { return 'MessageDetailsHeader--Read'; } if (sendStatus === SendStatus.Delivered) { return 'MessageDetailsHeader--Delivered'; } if (sendStatus === SendStatus.Sent) { return 'MessageDetailsHeader--Sent'; } if (sendStatus === SendStatus.Pending) { return 'MessageDetailsHeader--Pending'; } return 'from'; } export const StoryDetailsModal = ({ getPreferredBadge, i18n, onClose, sender, sendState, size, timestamp, }: PropsType): JSX.Element => { const contactsBySendStatus = sendState ? groupBy(sendState, contact => contact.status) : undefined; let content: JSX.Element; if (contactsBySendStatus) { content = (
{[ SendStatus.Failed, SendStatus.Viewed, SendStatus.Read, SendStatus.Delivered, SendStatus.Sent, SendStatus.Pending, ].map(sendStatus => { const contacts = contactsBySendStatus.get(sendStatus); if (!contacts) { return null; } const i18nKey = getI18nKey(sendStatus); const sortedContacts = [...contacts].sort((a, b) => contactSortCollator.compare(a.recipient.title, b.recipient.title) ); return (
{i18n(i18nKey)}
{sortedContacts.map(status => { const contact = status.recipient; return (
{status.updatedAt && ( )}
); })}
); })}
); } else { content = (
{i18n('sent')}
); } return ( { window.navigator.clipboard.writeText(String(timestamp)); }, }, ]} moduleClassName="StoryDetailsModal__debugger" popperOptions={{ placement: 'bottom', strategy: 'absolute', }} theme={Theme.Dark} >
{formatDateTimeLong(i18n, timestamp)} , ]} />
{size && (
{formatFileSize(size)} , ]} />
)} } > {content}
); };