// Copyright 2023 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import type { LocalizerType } from '../types/I18N'; import type { NavTabPanelProps } from './NavTabs'; import { WhatsNewLink } from './WhatsNewLink'; import type { UnreadStats } from '../util/countUnreadStats'; type ChatsTabProps = Readonly<{ otherTabsUnreadStats: UnreadStats; i18n: LocalizerType; isStaging: boolean; hasPendingUpdate: boolean; hasFailedStorySends: boolean; navTabsCollapsed: boolean; onToggleNavTabsCollapse: (navTabsCollapsed: boolean) => void; renderConversationView: () => JSX.Element; renderLeftPane: (props: NavTabPanelProps) => JSX.Element; renderMiniPlayer: (options: { shouldFlow: boolean }) => JSX.Element; selectedConversationId: string | undefined; showWhatsNewModal: () => unknown; }>; export function ChatsTab({ otherTabsUnreadStats, i18n, isStaging, hasPendingUpdate, hasFailedStorySends, navTabsCollapsed, onToggleNavTabsCollapse, renderConversationView, renderLeftPane, renderMiniPlayer, selectedConversationId, showWhatsNewModal, }: ChatsTabProps): JSX.Element { return ( <>
{renderLeftPane({ otherTabsUnreadStats, collapsed: navTabsCollapsed, hasPendingUpdate, hasFailedStorySends, onToggleCollapse: onToggleNavTabsCollapse, })}
{selectedConversationId ? (
{renderConversationView()}
) : (
{renderMiniPlayer({ shouldFlow: false })}

{isStaging ? 'THIS IS A STAGING DESKTOP' : i18n('icu:welcomeToSignal')}

)}
); }