signal-desktop/ts/state/smart/ForwardMessageModal.tsx

88 lines
2.6 KiB
TypeScript
Raw Normal View History

2021-04-27 22:35:35 +00:00
// Copyright 2021 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import { connect } from 'react-redux';
2022-06-17 00:48:57 +00:00
import type { AttachmentType } from '../../types/Attachment';
import type { BodyRangeType } from '../../types/Util';
2022-06-17 00:48:57 +00:00
import type { DataPropsType } from '../../components/ForwardMessageModal';
import type { LinkPreviewType } from '../../types/message/LinkPreviews';
2022-06-17 00:48:57 +00:00
import type { StateType } from '../reducer';
import { ForwardMessageModal } from '../../components/ForwardMessageModal';
import { LinkPreviewSourceType } from '../../types/LinkPreview';
2021-04-27 22:35:35 +00:00
import { getAllComposableConversations } from '../selectors/conversations';
import { getEmojiSkinTone } from '../selectors/items';
2022-06-17 00:48:57 +00:00
import { getIntl, getTheme, getRegionCode } from '../selectors/user';
import { getLinkPreview } from '../selectors/linkPreviews';
import { getPreferredBadgeSelector } from '../selectors/badges';
import { mapDispatchToProps } from '../actions';
2021-04-27 22:35:35 +00:00
import { selectRecentEmojis } from '../selectors/emojis';
export type SmartForwardMessageModalProps = {
2021-12-03 01:05:32 +00:00
attachments?: Array<AttachmentType>;
2021-04-27 22:35:35 +00:00
doForwardMessage: (
selectedContacts: Array<string>,
messageBody?: string,
2021-12-03 01:05:32 +00:00
attachments?: Array<AttachmentType>,
2021-04-27 22:35:35 +00:00
linkPreview?: LinkPreviewType
) => void;
hasContact: boolean;
2021-04-27 22:35:35 +00:00
isSticker: boolean;
messageBody?: string;
onClose: () => void;
onEditorStateChange: (
messageText: string,
bodyRanges: Array<BodyRangeType>,
caretLocation?: number
) => unknown;
onTextTooLong: () => void;
};
const mapStateToProps = (
state: StateType,
props: SmartForwardMessageModalProps
): DataPropsType => {
const {
attachments,
doForwardMessage,
hasContact,
2021-04-27 22:35:35 +00:00
isSticker,
messageBody,
onClose,
onEditorStateChange,
onTextTooLong,
} = props;
const candidateConversations = getAllComposableConversations(state);
const recentEmojis = selectRecentEmojis(state);
const skinTone = getEmojiSkinTone(state);
2022-06-17 00:48:57 +00:00
const linkPreviewForSource = getLinkPreview(state);
2021-04-27 22:35:35 +00:00
return {
attachments,
candidateConversations,
doForwardMessage,
2021-11-17 18:38:52 +00:00
getPreferredBadge: getPreferredBadgeSelector(state),
hasContact,
2021-04-27 22:35:35 +00:00
i18n: getIntl(state),
isSticker,
2022-06-17 00:48:57 +00:00
linkPreview: linkPreviewForSource(
LinkPreviewSourceType.ForwardMessageModal
),
2021-04-27 22:35:35 +00:00
messageBody,
onClose,
onEditorStateChange,
recentEmojis,
skinTone,
onTextTooLong,
2021-11-02 23:01:13 +00:00
theme: getTheme(state),
regionCode: getRegionCode(state),
2021-04-27 22:35:35 +00:00
};
};
const smart = connect(mapStateToProps, {
...mapDispatchToProps,
onPickEmoji: mapDispatchToProps.onUseEmoji,
});
export const SmartForwardMessageModal = smart(ForwardMessageModal);