// 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 { LocalizerType } from '../../types/Util'; import { areAllAttachmentsVisual, AttachmentType, getUrl, isImageAttachment, isVideoAttachment, } from '../../types/Attachment'; export type Props = Readonly<{ attachments: ReadonlyArray; i18n: LocalizerType; onAddAttachment?: () => void; onClickAttachment?: (attachment: AttachmentType) => void; onClose?: () => void; onCloseAttachment: (attachment: AttachmentType) => void; }>; const IMAGE_WIDTH = 120; const IMAGE_HEIGHT = 120; // This is a 1x1 black square. const BLANK_VIDEO_THUMBNAIL = ''; 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); if (isImage || isVideo || attachment.pending) { const clickCallback = attachments.length > 1 ? onClickAttachment : undefined; const imageUrl = url || (isVideo ? BLANK_VIDEO_THUMBNAIL : undefined); return ( {i18n('stagedImageAttachment', { onCloseAttachment(attachment); }} /> ); } return ( ); })} {allVisualAttachments && onAddAttachment ? ( ) : null}
); };