// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import { connect } from 'react-redux'; import { mapDispatchToProps } from '../actions'; import { ConversationView } from '../../components/conversation/ConversationView'; import type { StateType } from '../reducer'; import type { CompositionAreaPropsType } from './CompositionArea'; import { SmartCompositionArea } from './CompositionArea'; import type { OwnProps as ConversationHeaderPropsType } from './ConversationHeader'; import { SmartConversationHeader } from './ConversationHeader'; import type { TimelinePropsType } from './Timeline'; import { SmartTimeline } from './Timeline'; export type PropsType = { compositionAreaProps: Pick< CompositionAreaPropsType, | 'clearQuotedMessage' | 'compositionApi' | 'getQuotedMessage' | 'handleClickQuotedMessage' | 'id' | 'onAccept' | 'onBlock' | 'onBlockAndReportSpam' | 'onCancelJoinRequest' | 'onClearAttachments' | 'onClickAddPack' | 'onCloseLinkPreview' | 'onDelete' | 'onEditorStateChange' | 'onPickSticker' | 'onSelectMediaQuality' | 'onSendMessage' | 'onStartGroupMigration' | 'onTextTooLong' | 'onUnblock' | 'openConversation' >; conversationHeaderProps: ConversationHeaderPropsType; timelineProps: TimelinePropsType; }; const mapStateToProps = (_state: StateType, props: PropsType) => { const { compositionAreaProps, conversationHeaderProps, timelineProps } = props; return { renderCompositionArea: () => ( ), renderConversationHeader: () => ( ), renderTimeline: () => , }; }; const smart = connect(mapStateToProps, mapDispatchToProps); export const SmartConversationView = smart(ConversationView);