// Copyright 2022 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import { useSelector } from 'react-redux'; import type { GetStoriesByConversationIdType } from '../selectors/stories'; import type { LocalizerType } from '../../types/Util'; import type { StateType } from '../reducer'; import { StoryViewer } from '../../components/StoryViewer'; import { ToastMessageBodyTooLong } from '../../components/ToastMessageBodyTooLong'; import { getEmojiSkinTone, getHasAllStoriesMuted, getPreferredReactionEmoji, } from '../selectors/items'; import { getIntl } from '../selectors/user'; import { getPreferredBadgeSelector } from '../selectors/badges'; import { getStoriesSelector, getStoryReplies } from '../selectors/stories'; import { renderEmojiPicker } from './renderEmojiPicker'; import { showToast } from '../../util/showToast'; import { useActions as useEmojisActions } from '../ducks/emojis'; import { useActions as useItemsActions } from '../ducks/items'; import { useConversationsActions } from '../ducks/conversations'; import { useRecentEmojis } from '../selectors/emojis'; import { useStoriesActions } from '../ducks/stories'; export type PropsType = { conversationId: string; onClose: () => unknown; onNextUserStories: () => unknown; onPrevUserStories: () => unknown; }; export function SmartStoryViewer({ conversationId, onClose, onNextUserStories, onPrevUserStories, }: PropsType): JSX.Element | null { const storiesActions = useStoriesActions(); const { onSetSkinTone, toggleHasAllStoriesMuted } = useItemsActions(); const { onUseEmoji } = useEmojisActions(); const { showConversation, toggleHideStories } = useConversationsActions(); const i18n = useSelector(getIntl); const getPreferredBadge = useSelector(getPreferredBadgeSelector); const preferredReactionEmoji = useSelector>( getPreferredReactionEmoji ); const getStoriesByConversationId = useSelector< StateType, GetStoriesByConversationIdType >(getStoriesSelector); const { group, stories } = getStoriesByConversationId(conversationId); const recentEmojis = useRecentEmojis(); const skinTone = useSelector(getEmojiSkinTone); const replyState = useSelector(getStoryReplies); const hasAllStoriesMuted = useSelector( getHasAllStoriesMuted ); return ( { showConversation({ conversationId: senderId }); storiesActions.toggleStoriesView(); }} onNextUserStories={onNextUserStories} onPrevUserStories={onPrevUserStories} onReactToStory={async (emoji, story) => { const { messageId } = story; storiesActions.reactToStory(emoji, messageId); }} onReplyToStory={(message, mentions, timestamp, story) => { storiesActions.replyToStory( conversationId, message, mentions, timestamp, story ); }} onSetSkinTone={onSetSkinTone} onTextTooLong={() => showToast(ToastMessageBodyTooLong)} onUseEmoji={onUseEmoji} preferredReactionEmoji={preferredReactionEmoji} recentEmojis={recentEmojis} renderEmojiPicker={renderEmojiPicker} replyState={replyState} stories={stories} skinTone={skinTone} toggleHasAllStoriesMuted={toggleHasAllStoriesMuted} {...storiesActions} /> ); }