// Copyright 2018-2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import { Image } from './Image'; import { StagedGenericAttachment } from './StagedGenericAttachment'; import { StagedPlaceholderAttachment } from './StagedPlaceholderAttachment'; import type { LocalizerType } from '../../types/Util'; import type { AttachmentDraftType } from '../../types/Attachment'; import { areAllAttachmentsVisual, isImageAttachment, isVideoAttachment, } from '../../types/Attachment'; export type Props = Readonly<{ attachments: ReadonlyArray; i18n: LocalizerType; onAddAttachment?: () => void; onClickAttachment?: (attachment: AttachmentDraftType) => void; onClose?: () => void; onCloseAttachment: (attachment: AttachmentDraftType) => void; }>; const IMAGE_WIDTH = 120; const IMAGE_HEIGHT = 120; // This is a 1x1 black square. const BLANK_VIDEO_THUMBNAIL = ''; function getUrl(attachment: AttachmentDraftType): string | undefined { if (attachment.pending) { return undefined; } return attachment.url; } export const AttachmentList = ({ attachments, i18n, onAddAttachment, onClickAttachment, onCloseAttachment, onClose, }: Props): JSX.Element | null => { if (!attachments.length) { return null; } const allVisualAttachments = areAllAttachmentsVisual(attachments); return (
{onClose && attachments.length > 1 ? (
) : null}
{(attachments || []).map((attachment, index) => { const url = getUrl(attachment); const key = url || attachment.path || attachment.fileName || index; const isImage = isImageAttachment(attachment); const isVideo = isVideoAttachment(attachment); const closeAttachment = () => onCloseAttachment(attachment); if (isImage || isVideo || attachment.pending) { const isDownloaded = !attachment.pending; const imageUrl = url || (isVideo ? BLANK_VIDEO_THUMBNAIL : undefined); const clickAttachment = onClickAttachment ? () => onClickAttachment(attachment) : undefined; return ( {i18n('stagedImageAttachment', ); } return ( ); })} {allVisualAttachments && onAddAttachment ? ( ) : null}
); };