fix: bring back notification submenu to both context menu

pull/2793/head
Audric Ackermann 2 years ago
parent cd14180b63
commit d970887caa

@ -1,14 +1,8 @@
import React from 'react'; import React from 'react';
import { animation, Item, Menu, Submenu } from 'react-contexify'; import { animation, Item, Menu, Submenu } from 'react-contexify';
import { useSelector } from 'react-redux'; import { useSelector } from 'react-redux';
import { import { setDisappearingMessagesByConvoId } from '../../interactions/conversationInteractions';
setDisappearingMessagesByConvoId, import { isSearching } from '../../state/selectors/search';
setNotificationForConvoId,
} from '../../interactions/conversationInteractions';
import {
ConversationNotificationSetting,
ConversationNotificationSettingType,
} from '../../models/conversationAttributes';
import { import {
useSelectedConversationKey, useSelectedConversationKey,
useSelectedIsActive, useSelectedIsActive,
@ -18,10 +12,9 @@ import {
useSelectedIsPrivate, useSelectedIsPrivate,
useSelectedIsPrivateFriend, useSelectedIsPrivateFriend,
useSelectedIsPublic, useSelectedIsPublic,
useSelectedNotificationSetting,
} from '../../state/selectors/selectedConversation'; } from '../../state/selectors/selectedConversation';
import { getTimerOptions } from '../../state/selectors/timerOptions'; import { getTimerOptions } from '../../state/selectors/timerOptions';
import { LocalizerKeys } from '../../types/LocalizerKeys'; import { ContextConversationProvider } from '../leftpane/conversation-list-item/ConvoIdContext';
import { SessionContextMenuContainer } from '../SessionContextMenuContainer'; import { SessionContextMenuContainer } from '../SessionContextMenuContainer';
import { import {
AddModeratorsMenuItem, AddModeratorsMenuItem,
@ -29,21 +22,20 @@ import {
BlockMenuItem, BlockMenuItem,
ChangeNicknameMenuItem, ChangeNicknameMenuItem,
ClearNicknameMenuItem, ClearNicknameMenuItem,
DeletePrivateContactMenuItem, CopyMenuItem,
DeleteGroupOrCommunityMenuItem, DeleteGroupOrCommunityMenuItem,
DeleteMessagesMenuItem, DeleteMessagesMenuItem,
DeletePrivateContactMenuItem,
DeletePrivateConversationMenuItem,
InviteContactMenuItem, InviteContactMenuItem,
LeaveGroupMenuItem, LeaveGroupMenuItem,
MarkAllReadMenuItem, MarkAllReadMenuItem,
NotificationForConvoMenuItem,
RemoveModeratorsMenuItem, RemoveModeratorsMenuItem,
ShowUserDetailsMenuItem, ShowUserDetailsMenuItem,
UnbanMenuItem, UnbanMenuItem,
UpdateGroupNameMenuItem, UpdateGroupNameMenuItem,
DeletePrivateConversationMenuItem,
CopyMenuItem,
} from './Menu'; } from './Menu';
import { ContextConversationProvider } from '../leftpane/conversation-list-item/ConvoIdContext';
import { isSearching } from '../../state/selectors/search';
export type PropsConversationHeaderMenu = { export type PropsConversationHeaderMenu = {
triggerId: string; triggerId: string;
@ -145,71 +137,3 @@ const DisappearingMessageMenuItem = (): JSX.Element | null => {
</Submenu> </Submenu>
); );
}; };
/**
* Only accessible through the triple dots menu on the conversation header. Not on the Conversation list item, because there is too much to check for before showing it
*/
const NotificationForConvoMenuItem = (): JSX.Element | null => {
const selectedConvoId = useSelectedConversationKey();
const currentNotificationSetting = useSelectedNotificationSetting();
const isBlocked = useSelectedIsBlocked();
const isActive = useSelectedIsActive();
const isLeft = useSelectedIsLeft();
const isKickedFromGroup = useSelectedIsKickedFromGroup();
const isFriend = useSelectedIsPrivateFriend();
const isPrivate = useSelectedIsPrivate();
if (
!selectedConvoId ||
isLeft ||
isKickedFromGroup ||
isBlocked ||
!isActive ||
(isPrivate && !isFriend)
) {
return null;
}
// const isRtlMode = isRtlBody();'
// exclude mentions_only settings for private chats as this does not make much sense
const notificationForConvoOptions = ConversationNotificationSetting.filter(n =>
isPrivate ? n !== 'mentions_only' : true
).map((n: ConversationNotificationSettingType) => {
// do this separately so typescript's compiler likes it
const keyToUse: LocalizerKeys =
n === 'all' || !n
? 'notificationForConvo_all'
: n === 'disabled'
? 'notificationForConvo_disabled'
: 'notificationForConvo_mentions_only';
return { value: n, name: window.i18n(keyToUse) };
});
return (
// Remove the && false to make context menu work with RTL support
<Submenu
label={window.i18n('notificationForConvo') as any}
// rtl={isRtlMode && false}
>
{(notificationForConvoOptions || []).map(item => {
const disabled = item.value === currentNotificationSetting;
return (
<Item
key={item.value}
onClick={async () => {
await setNotificationForConvoId(selectedConvoId, item.value);
}}
disabled={disabled}
>
{item.name}
</Item>
);
})}
</Submenu>
);
return null;
};

@ -27,6 +27,7 @@ import {
ShowUserDetailsMenuItem, ShowUserDetailsMenuItem,
UnbanMenuItem, UnbanMenuItem,
DeletePrivateConversationMenuItem, DeletePrivateConversationMenuItem,
NotificationForConvoMenuItem,
} from './Menu'; } from './Menu';
import { isSearching } from '../../state/selectors/search'; import { isSearching } from '../../state/selectors/search';
@ -51,6 +52,8 @@ const ConversationListItemContextMenu = (props: PropsContextConversationItem) =>
<DeclineAndBlockMsgRequestMenuItem /> <DeclineAndBlockMsgRequestMenuItem />
{/* Generic actions */} {/* Generic actions */}
<PinConversationMenuItem /> <PinConversationMenuItem />
<NotificationForConvoMenuItem />
<BlockMenuItem /> <BlockMenuItem />
<CopyMenuItem /> <CopyMenuItem />
{/* Read state actions */} {/* Read state actions */}

@ -1,6 +1,6 @@
import React from 'react'; import React from 'react';
import { Item } from 'react-contexify'; import { Item, Submenu } from 'react-contexify';
import { useDispatch, useSelector } from 'react-redux'; import { useDispatch, useSelector } from 'react-redux';
import { import {
useAvatarPath, useAvatarPath,
@ -25,6 +25,7 @@ import {
declineConversationWithConfirm, declineConversationWithConfirm,
deleteAllMessagesByConvoIdWithConfirmation, deleteAllMessagesByConvoIdWithConfirmation,
markAllReadByConvoId, markAllReadByConvoId,
setNotificationForConvoId,
showAddModeratorsByConvoId, showAddModeratorsByConvoId,
showBanUserByConvoId, showBanUserByConvoId,
showInviteContactByConvoId, showInviteContactByConvoId,
@ -42,9 +43,23 @@ import {
updateUserDetailsModal, updateUserDetailsModal,
} from '../../state/ducks/modalDialog'; } from '../../state/ducks/modalDialog';
import { getIsMessageSection } from '../../state/selectors/section'; import { getIsMessageSection } from '../../state/selectors/section';
import { useSelectedConversationKey } from '../../state/selectors/selectedConversation'; import {
useSelectedConversationKey,
useSelectedIsActive,
useSelectedIsBlocked,
useSelectedIsKickedFromGroup,
useSelectedIsLeft,
useSelectedIsPrivate,
useSelectedIsPrivateFriend,
useSelectedNotificationSetting,
} from '../../state/selectors/selectedConversation';
import { SessionButtonColor } from '../basic/SessionButton'; import { SessionButtonColor } from '../basic/SessionButton';
import { useConvoIdFromContext } from '../leftpane/conversation-list-item/ConvoIdContext'; import { useConvoIdFromContext } from '../leftpane/conversation-list-item/ConvoIdContext';
import {
ConversationNotificationSetting,
ConversationNotificationSettingType,
} from '../../models/conversationAttributes';
import { LocalizerKeys } from '../../types/LocalizerKeys';
/** Menu items standardized */ /** Menu items standardized */
@ -539,3 +554,68 @@ export const DeclineAndBlockMsgRequestMenuItem = () => {
} }
return null; return null;
}; };
export const NotificationForConvoMenuItem = (): JSX.Element | null => {
const selectedConvoId = useSelectedConversationKey();
const currentNotificationSetting = useSelectedNotificationSetting();
const isBlocked = useSelectedIsBlocked();
const isActive = useSelectedIsActive();
const isLeft = useSelectedIsLeft();
const isKickedFromGroup = useSelectedIsKickedFromGroup();
const isFriend = useSelectedIsPrivateFriend();
const isPrivate = useSelectedIsPrivate();
if (
!selectedConvoId ||
isLeft ||
isKickedFromGroup ||
isBlocked ||
!isActive ||
(isPrivate && !isFriend)
) {
return null;
}
// const isRtlMode = isRtlBody();'
// exclude mentions_only settings for private chats as this does not make much sense
const notificationForConvoOptions = ConversationNotificationSetting.filter(n =>
isPrivate ? n !== 'mentions_only' : true
).map((n: ConversationNotificationSettingType) => {
// do this separately so typescript's compiler likes it
const keyToUse: LocalizerKeys =
n === 'all' || !n
? 'notificationForConvo_all'
: n === 'disabled'
? 'notificationForConvo_disabled'
: 'notificationForConvo_mentions_only';
return { value: n, name: window.i18n(keyToUse) };
});
return (
// Remove the && false to make context menu work with RTL support
<Submenu
label={window.i18n('notificationForConvo') as any}
// rtl={isRtlMode && false}
>
{(notificationForConvoOptions || []).map(item => {
const disabled = item.value === currentNotificationSetting;
return (
<Item
key={item.value}
onClick={async () => {
await setNotificationForConvoId(selectedConvoId, item.value);
}}
disabled={disabled}
>
{item.name}
</Item>
);
})}
</Submenu>
);
return null;
};

Loading…
Cancel
Save