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.
		
		
		
		
		
			
		
			
				
	
	
		
			63 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
| import React, { useState } from 'react';
 | |
| import { animation, Menu } from 'react-contexify';
 | |
| import { ConversationTypeEnum } from '../../../models/conversation';
 | |
| 
 | |
| import {
 | |
|   getBlockMenuItem,
 | |
|   getChangeNicknameMenuItem,
 | |
|   getClearNicknameMenuItem,
 | |
|   getCopyMenuItem,
 | |
|   getDeleteContactMenuItem,
 | |
|   getDeleteMessagesMenuItem,
 | |
|   getInviteContactMenuItem,
 | |
|   getLeaveGroupMenuItem,
 | |
|   getMarkAllReadMenuItem,
 | |
| } from './Menu';
 | |
| 
 | |
| export type PropsContextConversationItem = {
 | |
|   id: string;
 | |
|   triggerId: string;
 | |
|   type: ConversationTypeEnum;
 | |
|   isMe: boolean;
 | |
|   isPublic?: boolean;
 | |
|   isBlocked?: boolean;
 | |
|   hasNickname?: boolean;
 | |
|   isKickedFromGroup?: boolean;
 | |
|   left?: boolean;
 | |
|   theme?: any;
 | |
| };
 | |
| 
 | |
| export const ConversationListItemContextMenu = (props: PropsContextConversationItem) => {
 | |
|   const {
 | |
|     id: conversationId,
 | |
|     triggerId,
 | |
|     isBlocked,
 | |
|     isMe,
 | |
|     isPublic,
 | |
|     hasNickname,
 | |
|     type,
 | |
|     left,
 | |
|     isKickedFromGroup,
 | |
|     theme,
 | |
|   } = props;
 | |
| 
 | |
|   const isGroup = type === 'group';
 | |
| 
 | |
|   return (
 | |
|     <>
 | |
|       <Menu id={triggerId} animation={animation.fade}>
 | |
|         {getBlockMenuItem(isMe, type === ConversationTypeEnum.PRIVATE, isBlocked, conversationId)}
 | |
|         {getCopyMenuItem(isPublic, isGroup, conversationId)}
 | |
|         {getMarkAllReadMenuItem(conversationId)}
 | |
|         {getChangeNicknameMenuItem(isMe, isGroup, conversationId)}
 | |
|         {getClearNicknameMenuItem(isMe, hasNickname, isGroup, conversationId)}
 | |
| 
 | |
|         {getDeleteMessagesMenuItem(isPublic, conversationId)}
 | |
|         {getInviteContactMenuItem(isGroup, isPublic, conversationId)}
 | |
|         {getDeleteContactMenuItem(isMe, isGroup, isPublic, left, isKickedFromGroup, conversationId)}
 | |
|         {getLeaveGroupMenuItem(isKickedFromGroup, left, isGroup, isPublic, conversationId)}
 | |
|       </Menu>
 | |
|     </>
 | |
|   );
 | |
| };
 |