// Copyright 2022 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React, { useState } from 'react'; import classNames from 'classnames'; import type { ConversationType, ShowConversationType, } from '../state/ducks/conversations'; import type { ConversationStoryType, MyStoryType, StoryViewType, } from '../types/Stories'; import type { LocalizerType } from '../types/Util'; import type { PreferredBadgeSelectorType } from '../state/selectors/badges'; import type { PropsType as SmartStoryCreatorPropsType } from '../state/smart/StoryCreator'; import type { ShowToastActionCreatorType } from '../state/ducks/toast'; import type { ViewUserStoriesActionCreatorType, ViewStoryActionCreatorType, } from '../state/ducks/stories'; import { MyStories } from './MyStories'; import { StoriesPane } from './StoriesPane'; import { Theme, themeClassName } from '../util/theme'; import { getWidthFromPreferredWidth } from '../util/leftPaneWidth'; import { useEscapeHandling } from '../hooks/useEscapeHandling'; export type PropsType = { deleteStoryForEveryone: (story: StoryViewType) => unknown; getPreferredBadge: PreferredBadgeSelectorType; hiddenStories: Array; i18n: LocalizerType; me: ConversationType; myStories: Array; onForwardStory: (storyId: string) => unknown; onSaveStory: (story: StoryViewType) => unknown; preferredWidthFromStorage: number; queueStoryDownload: (storyId: string) => unknown; renderStoryCreator: (props: SmartStoryCreatorPropsType) => JSX.Element; showConversation: ShowConversationType; showStoriesSettings: () => unknown; showToast: ShowToastActionCreatorType; stories: Array; toggleHideStories: (conversationId: string) => unknown; toggleStoriesView: () => unknown; viewUserStories: ViewUserStoriesActionCreatorType; viewStory: ViewStoryActionCreatorType; isViewingStory: boolean; isStoriesSettingsVisible: boolean; hasReadReceiptSetting: boolean; }; type AddStoryType = | { type: 'Media'; file: File; } | { type: 'Text' } | undefined; export const Stories = ({ deleteStoryForEveryone, getPreferredBadge, hiddenStories, i18n, me, myStories, onForwardStory, onSaveStory, preferredWidthFromStorage, queueStoryDownload, renderStoryCreator, showConversation, showStoriesSettings, showToast, stories, toggleHideStories, toggleStoriesView, viewUserStories, viewStory, isViewingStory, isStoriesSettingsVisible, hasReadReceiptSetting, }: PropsType): JSX.Element => { const width = getWidthFromPreferredWidth(preferredWidthFromStorage, { requiresFullWidth: true, }); const [addStoryData, setAddStoryData] = useState(); const [isMyStories, setIsMyStories] = useState(false); // only handle ESC if not showing a child that handles their own ESC useEscapeHandling( (isMyStories && myStories.length) || isViewingStory || isStoriesSettingsVisible || addStoryData ? undefined : toggleStoriesView ); return (
{addStoryData && renderStoryCreator({ file: addStoryData.type === 'Media' ? addStoryData.file : undefined, onClose: () => setAddStoryData(undefined), })}
{isMyStories && myStories.length ? ( setIsMyStories(false)} onDelete={deleteStoryForEveryone} onForward={onForwardStory} onSave={onSaveStory} queueStoryDownload={queueStoryDownload} viewStory={viewStory} hasReadReceiptSetting={hasReadReceiptSetting} /> ) : ( file ? setAddStoryData({ type: 'Media', file }) : setAddStoryData({ type: 'Text' }) } onMyStoriesClicked={() => { if (myStories.length) { setIsMyStories(true); } else { setAddStoryData({ type: 'Text' }); } }} onStoriesSettings={showStoriesSettings} queueStoryDownload={queueStoryDownload} showConversation={showConversation} showToast={showToast} stories={stories} toggleHideStories={toggleHideStories} toggleStoriesView={toggleStoriesView} viewUserStories={viewUserStories} /> )}
{i18n('Stories__placeholder--text')}
); };