// Copyright 2022 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import { useSelector } from 'react-redux'; import type { LocalizerType } from '../../types/Util'; import type { StateType } from '../reducer'; import { LinkPreviewSourceType } from '../../types/LinkPreview'; import { SmartCompositionTextArea } from './CompositionTextArea'; import { StoryCreator } from '../../components/StoryCreator'; import { getAllSignalConnections, getCandidateContactsForNewGroup, getGroupStories, getMe, getNonGroupStories, selectMostRecentActiveStoryTimestampByGroupOrDistributionList, } from '../selectors/conversations'; import { getDistributionListsWithMembers } from '../selectors/storyDistributionLists'; import { getIntl, getUserConversationId } from '../selectors/user'; import { getInstalledStickerPacks, getRecentStickers, } from '../selectors/stickers'; import { getAddStoryData } from '../selectors/stories'; import { getEmojiSkinTone, getHasSetMyStoriesPrivacy, } from '../selectors/items'; import { getLinkPreview } from '../selectors/linkPreviews'; import { getPreferredBadgeSelector } from '../selectors/badges'; import { imageToBlurHash } from '../../util/imageToBlurHash'; import { processAttachment } from '../../util/processAttachment'; import { useConversationsActions } from '../ducks/conversations'; import { useActions as useEmojisActions } from '../ducks/emojis'; import { useGlobalModalActions } from '../ducks/globalModals'; import { useActions as useItemsActions } from '../ducks/items'; import { useLinkPreviewActions } from '../ducks/linkPreviews'; import { useRecentEmojis } from '../selectors/emojis'; import { useStoriesActions } from '../ducks/stories'; import { useStoryDistributionListsActions } from '../ducks/storyDistributionLists'; export type PropsType = { file?: File; onClose: () => unknown; }; export function SmartStoryCreator(): JSX.Element | null { const { debouncedMaybeGrabLinkPreview } = useLinkPreviewActions(); const { sendStoryModalOpenStateChanged, sendStoryMessage, verifyStoryListMembers, setAddStoryData, } = useStoriesActions(); const { toggleGroupsForStorySend } = useConversationsActions(); const { allowsRepliesChanged, createDistributionList, deleteDistributionList, hideMyStoriesFrom, removeMembersFromDistributionList, setMyStoriesToAllSignalConnections, updateStoryViewers, } = useStoryDistributionListsActions(); const { toggleSignalConnectionsModal } = useGlobalModalActions(); const ourConversationId = useSelector(getUserConversationId); const candidateConversations = useSelector(getCandidateContactsForNewGroup); const distributionLists = useSelector(getDistributionListsWithMembers); const getPreferredBadge = useSelector(getPreferredBadgeSelector); const groupConversations = useSelector(getNonGroupStories); const groupStories = useSelector(getGroupStories); const hasSetMyStoriesPrivacy = useSelector(getHasSetMyStoriesPrivacy); const i18n = useSelector(getIntl); const installedPacks = useSelector(getInstalledStickerPacks); const linkPreviewForSource = useSelector(getLinkPreview); const me = useSelector(getMe); const recentStickers = useSelector(getRecentStickers); const signalConnections = useSelector(getAllSignalConnections); const mostRecentActiveStoryTimestampByGroupOrDistributionList = useSelector( selectMostRecentActiveStoryTimestampByGroupOrDistributionList ); const addStoryData = useSelector(getAddStoryData); const file = addStoryData?.type === 'Media' ? addStoryData.file : undefined; const isSending = addStoryData?.sending || false; const recentEmojis = useRecentEmojis(); const skinTone = useSelector(getEmojiSkinTone); const { onSetSkinTone } = useItemsActions(); const { onUseEmoji } = useEmojisActions(); return ( setAddStoryData(undefined)} onDeleteList={deleteDistributionList} onDistributionListCreated={createDistributionList} onHideMyStoriesFrom={hideMyStoriesFrom} onRemoveMembers={removeMembersFromDistributionList} onRepliesNReactionsChanged={allowsRepliesChanged} onSelectedStoryList={verifyStoryListMembers} onSend={sendStoryMessage} onSetSkinTone={onSetSkinTone} onUseEmoji={onUseEmoji} onViewersUpdated={updateStoryViewers} ourConversationId={ourConversationId} processAttachment={processAttachment} recentEmojis={recentEmojis} recentStickers={recentStickers} renderCompositionTextArea={SmartCompositionTextArea} sendStoryModalOpenStateChanged={sendStoryModalOpenStateChanged} setMyStoriesToAllSignalConnections={setMyStoriesToAllSignalConnections} signalConnections={signalConnections} skinTone={skinTone} toggleGroupsForStorySend={toggleGroupsForStorySend} toggleSignalConnectionsModal={toggleSignalConnectionsModal} /> ); }