// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import classNames from 'classnames'; import { useEscapeHandling } from '../../hooks/useEscapeHandling'; export type PropsType = { conversationId: string; hasOpenModal: boolean; isSelectMode: boolean; onExitSelectMode: () => void; processAttachments: (options: { conversationId: string; files: ReadonlyArray; }) => void; renderCompositionArea: () => JSX.Element; renderConversationHeader: () => JSX.Element; renderTimeline: () => JSX.Element; renderPanel: () => JSX.Element | undefined; shouldHideConversationView?: boolean; }; export function ConversationView({ conversationId, hasOpenModal, isSelectMode, onExitSelectMode, processAttachments, renderCompositionArea, renderConversationHeader, renderTimeline, renderPanel, shouldHideConversationView, }: PropsType): JSX.Element { const onDrop = React.useCallback( (event: React.DragEvent) => { event.stopPropagation(); event.preventDefault(); if (!event.dataTransfer) { return; } if (event.dataTransfer.types[0] !== 'Files') { return; } const { files } = event.dataTransfer; processAttachments({ conversationId, files: Array.from(files), }); }, [conversationId, processAttachments] ); const onPaste = React.useCallback( (event: React.ClipboardEvent) => { event.stopPropagation(); event.preventDefault(); if (!event.clipboardData) { return; } const { items } = event.clipboardData; const allVisual = [...items].every(item => { const type = item.type.split('/')[0]; return type === 'image' || type === 'video'; }); if (allVisual) { const files: Array = []; for (let i = 0; i < items.length; i += 1) { const file = items[i].getAsFile(); if (file) { files.push(file); } } processAttachments({ conversationId, files, }); return; } const firstAttachment = items[0]?.getAsFile(); if (firstAttachment) { processAttachments({ conversationId, files: [firstAttachment], }); } }, [conversationId, processAttachments] ); useEscapeHandling( isSelectMode && !hasOpenModal ? onExitSelectMode : undefined ); return (
{renderConversationHeader()}
{renderTimeline()}
{renderCompositionArea()}
{renderPanel()}
); }