2022-09-30 14:50:45 +00:00
|
|
|
/* eslint-disable lines-around-comment */
|
|
|
|
|
|
|
|
import React, { useCallback } from 'react';
|
|
|
|
import { useTranslation } from 'react-i18next';
|
|
|
|
import { useDispatch, useSelector } from 'react-redux';
|
|
|
|
|
|
|
|
// @ts-ignore
|
|
|
|
import TogglePinToStageButton from '../../../../features/video-menu/components/web/TogglePinToStageButton';
|
|
|
|
// @ts-ignore
|
|
|
|
import { Avatar } from '../../../base/avatar';
|
|
|
|
import { IconShareVideo } from '../../../base/icons/svg';
|
2022-10-06 11:12:57 +00:00
|
|
|
import { isWhiteboardParticipant } from '../../../base/participants/functions';
|
2022-10-20 09:11:27 +00:00
|
|
|
import { IParticipant } from '../../../base/participants/types';
|
2022-10-06 10:09:40 +00:00
|
|
|
import ContextMenu from '../../../base/ui/components/web/ContextMenu';
|
|
|
|
import ContextMenuItemGroup from '../../../base/ui/components/web/ContextMenuItemGroup';
|
2022-09-30 14:50:45 +00:00
|
|
|
// @ts-ignore
|
|
|
|
import { stopSharedVideo } from '../../../shared-video/actions.any';
|
|
|
|
import { showOverflowDrawer } from '../../../toolbox/functions.web';
|
|
|
|
import { setWhiteboardOpen } from '../../../whiteboard/actions';
|
|
|
|
import { WHITEBOARD_ID } from '../../../whiteboard/constants';
|
|
|
|
|
2022-11-03 08:35:51 +00:00
|
|
|
interface IProps {
|
2022-09-30 14:50:45 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Class name for the context menu.
|
|
|
|
*/
|
|
|
|
className?: string;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Closes a drawer if open.
|
|
|
|
*/
|
|
|
|
closeDrawer?: () => void;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The participant for which the drawer is open.
|
|
|
|
* It contains the displayName & participantID.
|
|
|
|
*/
|
|
|
|
drawerParticipant?: {
|
|
|
|
displayName: string;
|
|
|
|
participantID: string;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Shared video local participant owner.
|
|
|
|
*/
|
|
|
|
localVideoOwner?: boolean;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Target elements against which positioning calculations are made.
|
|
|
|
*/
|
|
|
|
offsetTarget?: HTMLElement;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Callback for the mouse entering the component.
|
|
|
|
*/
|
|
|
|
onEnter?: (e?: React.MouseEvent) => void;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Callback for the mouse leaving the component.
|
|
|
|
*/
|
|
|
|
onLeave?: (e?: React.MouseEvent) => void;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Callback for making a selection in the menu.
|
|
|
|
*/
|
|
|
|
onSelect: (value?: boolean | React.MouseEvent) => void;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Participant reference.
|
|
|
|
*/
|
2022-10-20 09:11:27 +00:00
|
|
|
participant: IParticipant;
|
2022-09-30 14:50:45 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether or not the menu is displayed in the thumbnail remote video menu.
|
|
|
|
*/
|
|
|
|
thumbnailMenu?: boolean;
|
2022-11-03 08:35:51 +00:00
|
|
|
}
|
2022-09-30 14:50:45 +00:00
|
|
|
|
|
|
|
const FakeParticipantContextMenu = ({
|
|
|
|
className,
|
|
|
|
closeDrawer,
|
|
|
|
drawerParticipant,
|
|
|
|
localVideoOwner,
|
|
|
|
offsetTarget,
|
|
|
|
onEnter,
|
|
|
|
onLeave,
|
|
|
|
onSelect,
|
|
|
|
participant,
|
|
|
|
thumbnailMenu
|
2022-11-03 08:35:51 +00:00
|
|
|
}: IProps) => {
|
2022-09-30 14:50:45 +00:00
|
|
|
const dispatch = useDispatch();
|
|
|
|
const { t } = useTranslation();
|
|
|
|
const _overflowDrawer: boolean = useSelector(showOverflowDrawer);
|
|
|
|
|
|
|
|
const clickHandler = useCallback(() => onSelect(true), [ onSelect ]);
|
|
|
|
|
|
|
|
const _onStopSharedVideo = useCallback(() => {
|
|
|
|
clickHandler();
|
|
|
|
dispatch(stopSharedVideo());
|
|
|
|
}, [ stopSharedVideo ]);
|
|
|
|
|
|
|
|
const _onHideWhiteboard = useCallback(() => {
|
|
|
|
clickHandler();
|
|
|
|
dispatch(setWhiteboardOpen(false));
|
|
|
|
}, [ setWhiteboardOpen ]);
|
|
|
|
|
|
|
|
const _getActions = useCallback(() => {
|
2022-10-06 11:12:57 +00:00
|
|
|
if (isWhiteboardParticipant(participant)) {
|
2022-09-30 14:50:45 +00:00
|
|
|
return [ {
|
|
|
|
accessibilityLabel: t('toolbar.hideWhiteboard'),
|
|
|
|
icon: IconShareVideo,
|
|
|
|
onClick: _onHideWhiteboard,
|
|
|
|
text: t('toolbar.hideWhiteboard')
|
|
|
|
} ];
|
|
|
|
}
|
|
|
|
|
|
|
|
if (localVideoOwner) {
|
|
|
|
return [ {
|
|
|
|
accessibilityLabel: t('toolbar.stopSharedVideo'),
|
|
|
|
icon: IconShareVideo,
|
|
|
|
onClick: _onStopSharedVideo,
|
|
|
|
text: t('toolbar.stopSharedVideo')
|
|
|
|
} ];
|
|
|
|
}
|
2022-10-06 11:12:57 +00:00
|
|
|
}, [ localVideoOwner, participant.fakeParticipant ]);
|
2022-09-30 14:50:45 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<ContextMenu
|
|
|
|
className = { className }
|
|
|
|
entity = { participant }
|
|
|
|
hidden = { thumbnailMenu ? false : undefined }
|
|
|
|
inDrawer = { thumbnailMenu && _overflowDrawer }
|
|
|
|
isDrawerOpen = { Boolean(drawerParticipant) }
|
|
|
|
offsetTarget = { offsetTarget }
|
|
|
|
onClick = { onSelect }
|
|
|
|
onDrawerClose = { thumbnailMenu ? onSelect : closeDrawer }
|
|
|
|
onMouseEnter = { onEnter }
|
|
|
|
onMouseLeave = { onLeave }>
|
|
|
|
{!thumbnailMenu && _overflowDrawer && drawerParticipant && <ContextMenuItemGroup
|
|
|
|
actions = { [ {
|
|
|
|
accessibilityLabel: drawerParticipant.displayName,
|
|
|
|
customIcon: <Avatar
|
|
|
|
participantId = { drawerParticipant.participantID }
|
|
|
|
size = { 20 } />,
|
|
|
|
text: drawerParticipant.displayName
|
|
|
|
} ] } />}
|
|
|
|
|
|
|
|
<ContextMenuItemGroup
|
|
|
|
actions = { _getActions() }>
|
2022-10-06 11:12:57 +00:00
|
|
|
{isWhiteboardParticipant(participant) && (
|
|
|
|
<TogglePinToStageButton
|
|
|
|
key = 'pinToStage'
|
|
|
|
participantID = { WHITEBOARD_ID } />
|
|
|
|
)}
|
2022-09-30 14:50:45 +00:00
|
|
|
</ContextMenuItemGroup>
|
|
|
|
|
|
|
|
</ContextMenu>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default FakeParticipantContextMenu;
|