You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

GrantModeratorButton.tsx 2.2KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. import React, { useCallback, useMemo } from 'react';
  2. import { useTranslation } from 'react-i18next';
  3. import { useDispatch, useSelector } from 'react-redux';
  4. import { IReduxState } from '../../../app/types';
  5. import { openDialog } from '../../../base/dialog/actions';
  6. import { IconModerator } from '../../../base/icons/svg';
  7. import { PARTICIPANT_ROLE } from '../../../base/participants/constants';
  8. import { getLocalParticipant, getParticipantById, isParticipantModerator } from '../../../base/participants/functions';
  9. import ContextMenuItem from '../../../base/ui/components/web/ContextMenuItem';
  10. import { NOTIFY_CLICK_MODE } from '../../../toolbox/constants';
  11. import { IButtonProps } from '../../types';
  12. import GrantModeratorDialog from './GrantModeratorDialog';
  13. /**
  14. * Implements a React {@link Component} which displays a button for granting
  15. * moderator to a participant.
  16. *
  17. * @returns {JSX.Element|null}
  18. */
  19. const GrantModeratorButton = ({
  20. notifyClick,
  21. notifyMode,
  22. participantID
  23. }: IButtonProps): JSX.Element | null => {
  24. const { t } = useTranslation();
  25. const dispatch = useDispatch();
  26. const localParticipant = useSelector(getLocalParticipant);
  27. const targetParticipant = useSelector((state: IReduxState) => getParticipantById(state, participantID));
  28. const visible = useMemo(() => Boolean(localParticipant?.role === PARTICIPANT_ROLE.MODERATOR)
  29. && !isParticipantModerator(targetParticipant), [ isParticipantModerator, localParticipant, targetParticipant ]);
  30. const handleClick = useCallback(() => {
  31. notifyClick?.();
  32. if (notifyMode === NOTIFY_CLICK_MODE.PREVENT_AND_NOTIFY) {
  33. return;
  34. }
  35. dispatch(openDialog(GrantModeratorDialog, { participantID }));
  36. }, [ dispatch, notifyClick, notifyMode, participantID ]);
  37. if (!visible) {
  38. return null;
  39. }
  40. return (
  41. <ContextMenuItem
  42. accessibilityLabel = { t('toolbar.accessibilityLabel.grantModerator') }
  43. className = 'grantmoderatorlink'
  44. icon = { IconModerator }
  45. onClick = { handleClick }
  46. text = { t('videothumbnail.grantModerator') } />
  47. );
  48. };
  49. export default GrantModeratorButton;