2023-08-09 00:53:06 +00:00
|
|
|
// Copyright 2023 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
import React from 'react';
|
|
|
|
import { Environment, getEnvironment } from '../environment';
|
|
|
|
import type { LocalizerType } from '../types/I18N';
|
|
|
|
import type { NavTabPanelProps } from './NavTabs';
|
|
|
|
import { WhatsNewLink } from './WhatsNewLink';
|
2023-08-14 23:28:47 +00:00
|
|
|
import type { UnreadStats } from '../util/countUnreadStats';
|
2023-08-09 00:53:06 +00:00
|
|
|
|
|
|
|
type ChatsTabProps = Readonly<{
|
2023-08-21 20:12:27 +00:00
|
|
|
otherTabsUnreadStats: UnreadStats;
|
2023-08-09 00:53:06 +00:00
|
|
|
i18n: LocalizerType;
|
2023-08-14 23:28:47 +00:00
|
|
|
hasPendingUpdate: boolean;
|
|
|
|
hasFailedStorySends: boolean;
|
2023-08-09 00:53:06 +00:00
|
|
|
navTabsCollapsed: boolean;
|
|
|
|
onToggleNavTabsCollapse: (navTabsCollapsed: boolean) => void;
|
|
|
|
prevConversationId: string | undefined;
|
|
|
|
renderConversationView: () => JSX.Element;
|
|
|
|
renderLeftPane: (props: NavTabPanelProps) => JSX.Element;
|
|
|
|
renderMiniPlayer: (options: { shouldFlow: boolean }) => JSX.Element;
|
|
|
|
selectedConversationId: string | undefined;
|
|
|
|
showWhatsNewModal: () => unknown;
|
|
|
|
}>;
|
|
|
|
|
|
|
|
export function ChatsTab({
|
2023-08-21 20:12:27 +00:00
|
|
|
otherTabsUnreadStats,
|
2023-08-09 00:53:06 +00:00
|
|
|
i18n,
|
2023-08-14 23:28:47 +00:00
|
|
|
hasPendingUpdate,
|
|
|
|
hasFailedStorySends,
|
2023-08-09 00:53:06 +00:00
|
|
|
navTabsCollapsed,
|
|
|
|
onToggleNavTabsCollapse,
|
|
|
|
prevConversationId,
|
|
|
|
renderConversationView,
|
|
|
|
renderLeftPane,
|
|
|
|
renderMiniPlayer,
|
|
|
|
selectedConversationId,
|
|
|
|
showWhatsNewModal,
|
|
|
|
}: ChatsTabProps): JSX.Element {
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<div id="LeftPane">
|
|
|
|
{renderLeftPane({
|
2023-08-21 20:12:27 +00:00
|
|
|
otherTabsUnreadStats,
|
2023-08-09 00:53:06 +00:00
|
|
|
collapsed: navTabsCollapsed,
|
2023-08-14 23:28:47 +00:00
|
|
|
hasPendingUpdate,
|
|
|
|
hasFailedStorySends,
|
2023-08-09 00:53:06 +00:00
|
|
|
onToggleCollapse: onToggleNavTabsCollapse,
|
|
|
|
})}
|
|
|
|
</div>
|
|
|
|
<div className="Inbox__conversation-stack">
|
|
|
|
<div id="toast" />
|
|
|
|
{selectedConversationId && (
|
|
|
|
<div
|
|
|
|
className="Inbox__conversation"
|
|
|
|
id={`conversation-${selectedConversationId}`}
|
|
|
|
>
|
|
|
|
{renderConversationView()}
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
{!prevConversationId && (
|
|
|
|
<div className="Inbox__no-conversation-open">
|
|
|
|
{renderMiniPlayer({ shouldFlow: false })}
|
|
|
|
<div className="module-splash-screen__logo module-img--128 module-logo-blue" />
|
|
|
|
<h3>
|
|
|
|
{getEnvironment() !== Environment.Staging
|
|
|
|
? i18n('icu:welcomeToSignal')
|
|
|
|
: 'THIS IS A STAGING DESKTOP'}
|
|
|
|
</h3>
|
|
|
|
<p>
|
|
|
|
<WhatsNewLink i18n={i18n} showWhatsNewModal={showWhatsNewModal} />
|
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
}
|