You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			340 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			TypeScript
		
	
			
		
		
	
	
			340 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			TypeScript
		
	
| import React from 'react';
 | |
| import { LocalizerType } from '../../../types/Util';
 | |
| import { NotificationForConvoOption, TimerOption } from '../../conversation/ConversationHeader';
 | |
| import { Item, Submenu } from 'react-contexify';
 | |
| import {
 | |
|   ConversationNotificationSetting,
 | |
|   ConversationNotificationSettingType,
 | |
| } from '../../../models/conversation';
 | |
| 
 | |
| function showTimerOptions(
 | |
|   isPublic: boolean,
 | |
|   isKickedFromGroup: boolean,
 | |
|   left: boolean,
 | |
|   isBlocked: boolean
 | |
| ): boolean {
 | |
|   return !isPublic && !left && !isKickedFromGroup && !isBlocked;
 | |
| }
 | |
| 
 | |
| function showNotificationConvo(
 | |
|   isKickedFromGroup: boolean,
 | |
|   left: boolean,
 | |
|   isBlocked: boolean
 | |
| ): boolean {
 | |
|   return !left && !isKickedFromGroup && !isBlocked;
 | |
| }
 | |
| 
 | |
| function showMemberMenu(isPublic: boolean, isGroup: boolean): boolean {
 | |
|   return !isPublic && isGroup;
 | |
| }
 | |
| 
 | |
| function showBlock(isMe: boolean, isPrivate: boolean): boolean {
 | |
|   return !isMe && isPrivate;
 | |
| }
 | |
| 
 | |
| function showClearNickname(isMe: boolean, hasNickname: boolean, isGroup: boolean): boolean {
 | |
|   return !isMe && hasNickname && !isGroup;
 | |
| }
 | |
| 
 | |
| function showChangeNickname(isMe: boolean, isGroup: boolean) {
 | |
|   return !isMe && !isGroup;
 | |
| }
 | |
| 
 | |
| function showDeleteMessages(isPublic: boolean): boolean {
 | |
|   return !isPublic;
 | |
| }
 | |
| 
 | |
| // we want to show the copyId for open groups and private chats only
 | |
| function showCopyId(isPublic: boolean, isGroup: boolean): boolean {
 | |
|   return !isGroup || isPublic;
 | |
| }
 | |
| 
 | |
| function showDeleteContact(
 | |
|   isMe: boolean,
 | |
|   isGroup: boolean,
 | |
|   isPublic: boolean,
 | |
|   isGroupLeft: boolean,
 | |
|   isKickedFromGroup: boolean
 | |
| ): boolean {
 | |
|   // you need to have left a closed group first to be able to delete it completely.
 | |
|   return (!isMe && !isGroup) || (isGroup && (isGroupLeft || isKickedFromGroup || isPublic));
 | |
| }
 | |
| 
 | |
| function showAddModerators(isAdmin: boolean, isKickedFromGroup: boolean): boolean {
 | |
|   return !isKickedFromGroup && isAdmin;
 | |
| }
 | |
| 
 | |
| function showRemoveModerators(isAdmin: boolean, isKickedFromGroup: boolean): boolean {
 | |
|   return !isKickedFromGroup && isAdmin;
 | |
| }
 | |
| 
 | |
| function showUpdateGroupName(isAdmin: boolean, isKickedFromGroup: boolean, left: boolean): boolean {
 | |
|   return !isKickedFromGroup && !left && isAdmin;
 | |
| }
 | |
| 
 | |
| function showLeaveGroup(
 | |
|   isKickedFromGroup: boolean,
 | |
|   left: boolean,
 | |
|   isGroup: boolean,
 | |
|   isPublic: boolean
 | |
| ): boolean {
 | |
|   return !isKickedFromGroup && !left && isGroup && !isPublic;
 | |
| }
 | |
| 
 | |
| function showInviteContact(isGroup: boolean, isPublic: boolean): boolean {
 | |
|   return isGroup && isPublic;
 | |
| }
 | |
| 
 | |
| /** Menu items standardized */
 | |
| 
 | |
| export function getInviteContactMenuItem(
 | |
|   isGroup: boolean | undefined,
 | |
|   isPublic: boolean | undefined,
 | |
|   action: any,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (showInviteContact(Boolean(isGroup), Boolean(isPublic))) {
 | |
|     return <Item onClick={action}>{i18n('inviteContacts')}</Item>;
 | |
|   }
 | |
|   return null;
 | |
| }
 | |
| 
 | |
| export function getDeleteContactMenuItem(
 | |
|   isMe: boolean | undefined,
 | |
|   isGroup: boolean | undefined,
 | |
|   isPublic: boolean | undefined,
 | |
|   isLeft: boolean | undefined,
 | |
|   isKickedFromGroup: boolean | undefined,
 | |
|   action: any,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (
 | |
|     showDeleteContact(
 | |
|       Boolean(isMe),
 | |
|       Boolean(isGroup),
 | |
|       Boolean(isPublic),
 | |
|       Boolean(isLeft),
 | |
|       Boolean(isKickedFromGroup)
 | |
|     )
 | |
|   ) {
 | |
|     if (isPublic) {
 | |
|       return <Item onClick={action}>{i18n('leaveGroup')}</Item>;
 | |
|     }
 | |
|     return <Item onClick={action}>{i18n('delete')}</Item>;
 | |
|   }
 | |
|   return null;
 | |
| }
 | |
| 
 | |
| export function getLeaveGroupMenuItem(
 | |
|   isKickedFromGroup: boolean | undefined,
 | |
|   left: boolean | undefined,
 | |
|   isGroup: boolean | undefined,
 | |
|   isPublic: boolean | undefined,
 | |
|   action: any,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (
 | |
|     showLeaveGroup(Boolean(isKickedFromGroup), Boolean(left), Boolean(isGroup), Boolean(isPublic))
 | |
|   ) {
 | |
|     return <Item onClick={action}>{i18n('leaveGroup')}</Item>;
 | |
|   }
 | |
|   return null;
 | |
| }
 | |
| 
 | |
| export function getUpdateGroupNameMenuItem(
 | |
|   isAdmin: boolean | undefined,
 | |
|   isKickedFromGroup: boolean | undefined,
 | |
|   left: boolean | undefined,
 | |
|   action: any,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (showUpdateGroupName(Boolean(isAdmin), Boolean(isKickedFromGroup), Boolean(left))) {
 | |
|     return <Item onClick={action}>{i18n('editGroup')}</Item>;
 | |
|   }
 | |
|   return null;
 | |
| }
 | |
| 
 | |
| export function getRemoveModeratorsMenuItem(
 | |
|   isAdmin: boolean | undefined,
 | |
|   isKickedFromGroup: boolean | undefined,
 | |
|   action: any,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (showRemoveModerators(Boolean(isAdmin), Boolean(isKickedFromGroup))) {
 | |
|     return <Item onClick={action}>{i18n('removeModerators')}</Item>;
 | |
|   }
 | |
|   return null;
 | |
| }
 | |
| 
 | |
| export function getAddModeratorsMenuItem(
 | |
|   isAdmin: boolean | undefined,
 | |
|   isKickedFromGroup: boolean | undefined,
 | |
|   action: any,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (showAddModerators(Boolean(isAdmin), Boolean(isKickedFromGroup))) {
 | |
|     return <Item onClick={action}>{i18n('addModerators')}</Item>;
 | |
|   }
 | |
|   return null;
 | |
| }
 | |
| 
 | |
| export function getCopyMenuItem(
 | |
|   isPublic: boolean | undefined,
 | |
|   isGroup: boolean | undefined,
 | |
|   action: any,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (showCopyId(Boolean(isPublic), Boolean(isGroup))) {
 | |
|     const copyIdLabel = isPublic ? i18n('copyOpenGroupURL') : i18n('copySessionID');
 | |
|     return <Item onClick={action}>{copyIdLabel}</Item>;
 | |
|   }
 | |
|   return null;
 | |
| }
 | |
| 
 | |
| export function getMarkAllReadMenuItem(action: any, i18n: LocalizerType): JSX.Element | null {
 | |
|   return <Item onClick={action}>{i18n('markAllAsRead')}</Item>;
 | |
| }
 | |
| 
 | |
| export function getDisappearingMenuItem(
 | |
|   isPublic: boolean | undefined,
 | |
|   isKickedFromGroup: boolean | undefined,
 | |
|   left: boolean | undefined,
 | |
|   isBlocked: boolean | undefined,
 | |
|   timerOptions: Array<TimerOption>,
 | |
|   action: any,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (
 | |
|     showTimerOptions(
 | |
|       Boolean(isPublic),
 | |
|       Boolean(isKickedFromGroup),
 | |
|       Boolean(left),
 | |
|       Boolean(isBlocked)
 | |
|     )
 | |
|   ) {
 | |
|     const isRtlMode = isRtlBody();
 | |
|     return (
 | |
|       // Remove the && false to make context menu work with RTL support
 | |
|       <Submenu
 | |
|         label={i18n('disappearingMessages') as any}
 | |
|         // rtl={isRtlMode && false}
 | |
|       >
 | |
|         {(timerOptions || []).map(item => (
 | |
|           <Item
 | |
|             key={item.value}
 | |
|             onClick={() => {
 | |
|               action(item.value);
 | |
|             }}
 | |
|           >
 | |
|             {item.name}
 | |
|           </Item>
 | |
|         ))}
 | |
|       </Submenu>
 | |
|     );
 | |
|   }
 | |
|   return null;
 | |
| }
 | |
| 
 | |
| export function getNotificationForConvoMenuItem(
 | |
|   isKickedFromGroup: boolean | undefined,
 | |
|   left: boolean | undefined,
 | |
|   isBlocked: boolean | undefined,
 | |
|   notificationForConvoOptions: Array<NotificationForConvoOption>,
 | |
|   currentNotificationSetting: ConversationNotificationSettingType,
 | |
|   action: (selected: ConversationNotificationSettingType) => any,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (showNotificationConvo(Boolean(isKickedFromGroup), Boolean(left), Boolean(isBlocked))) {
 | |
|     // const isRtlMode = isRtlBody();
 | |
|     return (
 | |
|       // Remove the && false to make context menu work with RTL support
 | |
|       <Submenu
 | |
|         label={i18n('notificationForConvo') as any}
 | |
|         // rtl={isRtlMode && false}
 | |
|       >
 | |
|         {(notificationForConvoOptions || []).map(item => (
 | |
|           // tslint:disable-next-line: use-simple-attributes
 | |
|           <Item
 | |
|             key={item.value}
 | |
|             onClick={() => {
 | |
|               action(item.value);
 | |
|             }}
 | |
|             disabled={item.value === currentNotificationSetting}
 | |
|           >
 | |
|             {item.name}
 | |
|           </Item>
 | |
|         ))}
 | |
|       </Submenu>
 | |
|     );
 | |
|   }
 | |
|   return null;
 | |
| }
 | |
| 
 | |
| export function isRtlBody(): boolean {
 | |
|   return ($('body') as any).hasClass('rtl');
 | |
| }
 | |
| 
 | |
| export function getShowMemberMenuItem(
 | |
|   isPublic: boolean | undefined,
 | |
|   isGroup: boolean | undefined,
 | |
|   action: any,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (showMemberMenu(Boolean(isPublic), Boolean(isGroup))) {
 | |
|     return <Item onClick={action}>{i18n('groupMembers')}</Item>;
 | |
|   }
 | |
|   return null;
 | |
| }
 | |
| 
 | |
| export function getBlockMenuItem(
 | |
|   isMe: boolean | undefined,
 | |
|   isPrivate: boolean | undefined,
 | |
|   isBlocked: boolean | undefined,
 | |
|   actionBlock: any,
 | |
|   actionUnblock: any,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (showBlock(Boolean(isMe), Boolean(isPrivate))) {
 | |
|     const blockTitle = isBlocked ? i18n('unblockUser') : i18n('blockUser');
 | |
|     const blockHandler = isBlocked ? actionUnblock : actionBlock;
 | |
|     return <Item onClick={blockHandler}>{blockTitle}</Item>;
 | |
|   }
 | |
|   return null;
 | |
| }
 | |
| 
 | |
| export function getClearNicknameMenuItem(
 | |
|   isMe: boolean | undefined,
 | |
|   hasNickname: boolean | undefined,
 | |
|   action: any,
 | |
|   isGroup: boolean | undefined,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (showClearNickname(Boolean(isMe), Boolean(hasNickname), Boolean(isGroup))) {
 | |
|     return <Item onClick={action}>{i18n('clearNickname')}</Item>;
 | |
|   }
 | |
|   return null;
 | |
| }
 | |
| 
 | |
| export function getChangeNicknameMenuItem(
 | |
|   isMe: boolean | undefined,
 | |
|   action: any,
 | |
|   isGroup: boolean | undefined,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (showChangeNickname(Boolean(isMe), Boolean(isGroup))) {
 | |
|     return <Item onClick={action}>{i18n('changeNickname')}</Item>;
 | |
|   }
 | |
|   return null;
 | |
| }
 | |
| 
 | |
| export function getDeleteMessagesMenuItem(
 | |
|   isPublic: boolean | undefined,
 | |
|   action: any,
 | |
|   i18n: LocalizerType
 | |
| ): JSX.Element | null {
 | |
|   if (showDeleteMessages(Boolean(isPublic))) {
 | |
|     return <Item onClick={action}>{i18n('deleteMessages')}</Item>;
 | |
|   }
 | |
|   return null;
 | |
| }
 |