2023-01-03 19:55:46 +00:00
|
|
|
// Copyright 2020 Signal Messenger, LLC
|
2020-11-11 17:36:05 +00:00
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import { mapDispatchToProps } from '../actions';
|
2021-10-26 19:15:33 +00:00
|
|
|
import type { PropsDataType } from '../../components/conversation/ContactModal';
|
|
|
|
import { ContactModal } from '../../components/conversation/ContactModal';
|
|
|
|
import type { StateType } from '../reducer';
|
2020-11-11 17:36:05 +00:00
|
|
|
|
2021-11-30 16:29:57 +00:00
|
|
|
import { getAreWeASubscriber } from '../selectors/items';
|
2021-11-11 16:23:00 +00:00
|
|
|
import { getIntl, getTheme } from '../selectors/user';
|
2021-11-02 23:01:13 +00:00
|
|
|
import { getBadgesSelector } from '../selectors/badges';
|
2020-11-11 17:36:05 +00:00
|
|
|
import { getConversationSelector } from '../selectors/conversations';
|
2022-07-22 00:44:35 +00:00
|
|
|
import { getHasStoriesSelector } from '../selectors/stories';
|
2020-11-11 17:36:05 +00:00
|
|
|
|
2021-09-21 22:37:10 +00:00
|
|
|
const mapStateToProps = (state: StateType): PropsDataType => {
|
|
|
|
const { contactId, conversationId } =
|
|
|
|
state.globalModals.contactModalState || {};
|
2020-11-11 17:36:05 +00:00
|
|
|
|
2021-09-21 22:37:10 +00:00
|
|
|
const currentConversation = getConversationSelector(state)(conversationId);
|
2020-11-11 17:36:05 +00:00
|
|
|
const contact = getConversationSelector(state)(contactId);
|
|
|
|
|
|
|
|
const areWeAdmin =
|
|
|
|
currentConversation && currentConversation.areWeAdmin
|
|
|
|
? currentConversation.areWeAdmin
|
|
|
|
: false;
|
|
|
|
|
2021-01-29 21:19:24 +00:00
|
|
|
let isMember = false;
|
|
|
|
let isAdmin = false;
|
|
|
|
if (contact && currentConversation && currentConversation.memberships) {
|
|
|
|
currentConversation.memberships.forEach(membership => {
|
2021-10-26 22:59:08 +00:00
|
|
|
if (membership.uuid === contact.uuid) {
|
2021-01-29 21:19:24 +00:00
|
|
|
isMember = true;
|
|
|
|
isAdmin = membership.isAdmin;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-07-22 00:44:35 +00:00
|
|
|
const hasStories = getHasStoriesSelector(state)(conversationId);
|
|
|
|
|
2020-11-11 17:36:05 +00:00
|
|
|
return {
|
2021-11-30 16:29:57 +00:00
|
|
|
areWeASubscriber: getAreWeASubscriber(state),
|
2020-11-11 17:36:05 +00:00
|
|
|
areWeAdmin,
|
2021-11-02 23:01:13 +00:00
|
|
|
badges: getBadgesSelector(state)(contact.badges),
|
2020-11-11 17:36:05 +00:00
|
|
|
contact,
|
2022-03-15 01:32:07 +00:00
|
|
|
conversation: currentConversation,
|
2022-07-22 00:44:35 +00:00
|
|
|
hasStories,
|
2020-11-11 17:36:05 +00:00
|
|
|
i18n: getIntl(state),
|
2021-01-29 21:19:24 +00:00
|
|
|
isAdmin,
|
2020-11-11 17:36:05 +00:00
|
|
|
isMember,
|
2021-11-11 16:23:00 +00:00
|
|
|
theme: getTheme(state),
|
2020-11-11 17:36:05 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
const smart = connect(mapStateToProps, mapDispatchToProps);
|
|
|
|
|
|
|
|
export const SmartContactModal = smart(ContactModal);
|