move all menu to react-contexify
parent
78843e81dd
commit
fe3cfb9e82
@ -0,0 +1,158 @@
|
|||||||
|
import React from 'react';
|
||||||
|
import { animation, Menu } from 'react-contexify';
|
||||||
|
import {
|
||||||
|
getAddModeratorsMenuItem,
|
||||||
|
getBlockMenuItem,
|
||||||
|
getCopyMenuItem,
|
||||||
|
getDeleteContactMenuItem,
|
||||||
|
getDeleteMessagesMenuItem,
|
||||||
|
getDisappearingMenuItem,
|
||||||
|
getInviteContactMenuItem,
|
||||||
|
getLeaveGroupMenuItem,
|
||||||
|
getRemoveModeratorsMenuItem,
|
||||||
|
getResetSessionMenuItem,
|
||||||
|
getShowSafetyNumberMenuItem,
|
||||||
|
getUpdateGroupNameMenuItem,
|
||||||
|
} from './Menu';
|
||||||
|
import { TimerOption } from '../../conversation/ConversationHeader';
|
||||||
|
|
||||||
|
export type PropsConversationHeaderMenu = {
|
||||||
|
triggerId: string;
|
||||||
|
isMe: boolean;
|
||||||
|
isPublic?: boolean;
|
||||||
|
isRss?: boolean;
|
||||||
|
isClosable?: boolean;
|
||||||
|
isKickedFromGroup?: boolean;
|
||||||
|
isGroup: boolean;
|
||||||
|
amMod: boolean;
|
||||||
|
timerOptions: Array<TimerOption>;
|
||||||
|
isPrivate: boolean;
|
||||||
|
isBlocked: boolean;
|
||||||
|
onDeleteMessages?: () => void;
|
||||||
|
onDeleteContact?: () => void;
|
||||||
|
onCopyPublicKey?: () => void;
|
||||||
|
onInviteContacts?: () => void;
|
||||||
|
|
||||||
|
onLeaveGroup: () => void;
|
||||||
|
onAddModerators: () => void;
|
||||||
|
onRemoveModerators: () => void;
|
||||||
|
onUpdateGroupName: () => void;
|
||||||
|
onBlockUser: () => void;
|
||||||
|
onUnblockUser: () => void;
|
||||||
|
onShowSafetyNumber: () => void;
|
||||||
|
onSetDisappearingMessages: (seconds: number) => void;
|
||||||
|
onResetSession: () => void;
|
||||||
|
};
|
||||||
|
|
||||||
|
export const ConversationHeaderMenu = (props: PropsConversationHeaderMenu) => {
|
||||||
|
const {
|
||||||
|
triggerId,
|
||||||
|
isMe,
|
||||||
|
isClosable,
|
||||||
|
isPublic,
|
||||||
|
isRss,
|
||||||
|
isGroup,
|
||||||
|
isKickedFromGroup,
|
||||||
|
amMod,
|
||||||
|
timerOptions,
|
||||||
|
isBlocked,
|
||||||
|
isPrivate,
|
||||||
|
|
||||||
|
onDeleteMessages,
|
||||||
|
onDeleteContact,
|
||||||
|
onCopyPublicKey,
|
||||||
|
onLeaveGroup,
|
||||||
|
onAddModerators,
|
||||||
|
onRemoveModerators,
|
||||||
|
onInviteContacts,
|
||||||
|
onUpdateGroupName,
|
||||||
|
onBlockUser,
|
||||||
|
onUnblockUser,
|
||||||
|
onShowSafetyNumber,
|
||||||
|
onResetSession,
|
||||||
|
onSetDisappearingMessages,
|
||||||
|
} = props;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Menu id={triggerId} animation={animation.fade}>
|
||||||
|
{getDisappearingMenuItem(
|
||||||
|
isPublic,
|
||||||
|
isRss,
|
||||||
|
isKickedFromGroup,
|
||||||
|
isBlocked,
|
||||||
|
timerOptions,
|
||||||
|
onSetDisappearingMessages,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
{getShowSafetyNumberMenuItem(
|
||||||
|
isPublic,
|
||||||
|
isRss,
|
||||||
|
isGroup,
|
||||||
|
isMe,
|
||||||
|
onShowSafetyNumber,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
{getResetSessionMenuItem(
|
||||||
|
isPublic,
|
||||||
|
isRss,
|
||||||
|
isGroup,
|
||||||
|
isBlocked,
|
||||||
|
onResetSession,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
{getBlockMenuItem(
|
||||||
|
isMe,
|
||||||
|
isPrivate,
|
||||||
|
isBlocked,
|
||||||
|
onBlockUser,
|
||||||
|
onUnblockUser,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
|
||||||
|
{getCopyMenuItem(isPublic, isRss, isGroup, onCopyPublicKey, window.i18n)}
|
||||||
|
{getDeleteMessagesMenuItem(isPublic, onDeleteMessages, window.i18n)}
|
||||||
|
{getAddModeratorsMenuItem(
|
||||||
|
amMod,
|
||||||
|
isKickedFromGroup,
|
||||||
|
onAddModerators,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
{getRemoveModeratorsMenuItem(
|
||||||
|
amMod,
|
||||||
|
isKickedFromGroup,
|
||||||
|
onRemoveModerators,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
{getUpdateGroupNameMenuItem(
|
||||||
|
amMod,
|
||||||
|
isKickedFromGroup,
|
||||||
|
onUpdateGroupName,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
{getLeaveGroupMenuItem(
|
||||||
|
isKickedFromGroup,
|
||||||
|
isGroup,
|
||||||
|
isPublic,
|
||||||
|
isRss,
|
||||||
|
onLeaveGroup,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
{/* TODO: add delete group */}
|
||||||
|
{getInviteContactMenuItem(
|
||||||
|
isGroup,
|
||||||
|
isPublic,
|
||||||
|
onInviteContacts,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
{getDeleteContactMenuItem(
|
||||||
|
isMe,
|
||||||
|
isClosable,
|
||||||
|
isGroup,
|
||||||
|
isPublic,
|
||||||
|
isRss,
|
||||||
|
onDeleteContact,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
</Menu>
|
||||||
|
);
|
||||||
|
};
|
@ -0,0 +1,112 @@
|
|||||||
|
import React from 'react';
|
||||||
|
import { animation, Menu } from 'react-contexify';
|
||||||
|
|
||||||
|
import {
|
||||||
|
getBlockMenuItem,
|
||||||
|
getClearNicknameMenuItem,
|
||||||
|
getCopyMenuItem,
|
||||||
|
getDeleteContactMenuItem,
|
||||||
|
getDeleteMessagesMenuItem,
|
||||||
|
getInviteContactMenuItem,
|
||||||
|
getLeaveGroupMenuItem,
|
||||||
|
} from './Menu';
|
||||||
|
|
||||||
|
export type PropsContextConversationItem = {
|
||||||
|
triggerId: string;
|
||||||
|
type: 'group' | 'direct';
|
||||||
|
isMe: boolean;
|
||||||
|
isPublic?: boolean;
|
||||||
|
isRss?: boolean;
|
||||||
|
isClosable?: boolean;
|
||||||
|
isBlocked?: boolean;
|
||||||
|
hasNickname?: boolean;
|
||||||
|
isKickedFromGroup?: boolean;
|
||||||
|
|
||||||
|
onDeleteMessages?: () => void;
|
||||||
|
onDeleteContact?: () => void;
|
||||||
|
onBlockContact?: () => void;
|
||||||
|
onCopyPublicKey?: () => void;
|
||||||
|
onUnblockContact?: () => void;
|
||||||
|
onInviteContacts?: () => void;
|
||||||
|
onClearNickname?: () => void;
|
||||||
|
};
|
||||||
|
|
||||||
|
export const ConversationListItemContextMenu = (
|
||||||
|
props: PropsContextConversationItem
|
||||||
|
) => {
|
||||||
|
const {
|
||||||
|
triggerId,
|
||||||
|
isBlocked,
|
||||||
|
isMe,
|
||||||
|
isClosable,
|
||||||
|
isRss,
|
||||||
|
isPublic,
|
||||||
|
hasNickname,
|
||||||
|
type,
|
||||||
|
isKickedFromGroup,
|
||||||
|
onDeleteContact,
|
||||||
|
onDeleteMessages,
|
||||||
|
onBlockContact,
|
||||||
|
onClearNickname,
|
||||||
|
onCopyPublicKey,
|
||||||
|
onUnblockContact,
|
||||||
|
onInviteContacts,
|
||||||
|
} = props;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Menu id={triggerId} animation={animation.fade}>
|
||||||
|
{getBlockMenuItem(
|
||||||
|
isMe,
|
||||||
|
type === 'direct',
|
||||||
|
isBlocked,
|
||||||
|
onBlockContact,
|
||||||
|
onUnblockContact,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
{/* {!isPublic && !isRss && !isMe ? (
|
||||||
|
<Item onClick={onChangeNickname}>
|
||||||
|
{i18n('changeNickname')}
|
||||||
|
</Item>
|
||||||
|
) : null} */}
|
||||||
|
{getClearNicknameMenuItem(
|
||||||
|
isPublic,
|
||||||
|
isRss,
|
||||||
|
isMe,
|
||||||
|
hasNickname,
|
||||||
|
onClearNickname,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
{getCopyMenuItem(
|
||||||
|
isPublic,
|
||||||
|
isRss,
|
||||||
|
type === 'group',
|
||||||
|
onCopyPublicKey,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
{getDeleteMessagesMenuItem(isPublic, onDeleteMessages, window.i18n)}
|
||||||
|
{getInviteContactMenuItem(
|
||||||
|
type === 'group',
|
||||||
|
isPublic,
|
||||||
|
onInviteContacts,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
{getDeleteContactMenuItem(
|
||||||
|
isMe,
|
||||||
|
isClosable,
|
||||||
|
type === 'group',
|
||||||
|
isPublic,
|
||||||
|
isRss,
|
||||||
|
onDeleteContact,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
{getLeaveGroupMenuItem(
|
||||||
|
isKickedFromGroup,
|
||||||
|
type === 'group',
|
||||||
|
isPublic,
|
||||||
|
isRss,
|
||||||
|
onDeleteContact,
|
||||||
|
window.i18n
|
||||||
|
)}
|
||||||
|
</Menu>
|
||||||
|
);
|
||||||
|
};
|
Loading…
Reference in New Issue