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.

HangupMenu.tsx 3.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. /* eslint-disable lines-around-comment */
  2. import React, { useCallback } from 'react';
  3. import { View } from 'react-native';
  4. import { useDispatch, useSelector } from 'react-redux';
  5. import { createBreakoutRoomsEvent, createToolbarEvent } from '../../../analytics/AnalyticsEvents';
  6. import { sendAnalytics } from '../../../analytics/functions';
  7. // @ts-ignore
  8. import { appNavigate } from '../../../app/actions';
  9. import { IReduxState } from '../../../app/types';
  10. import ColorSchemeRegistry from '../../../base/color-scheme/ColorSchemeRegistry';
  11. import { endConference } from '../../../base/conference/actions';
  12. import { hideSheet } from '../../../base/dialog/actions';
  13. // @ts-ignore
  14. import BottomSheet from '../../../base/dialog/components/native/BottomSheet';
  15. import { PARTICIPANT_ROLE } from '../../../base/participants/constants';
  16. import { getLocalParticipant } from '../../../base/participants/functions';
  17. import Button from '../../../base/ui/components/native/Button';
  18. import { BUTTON_TYPES } from '../../../base/ui/constants.native';
  19. import { moveToRoom } from '../../../breakout-rooms/actions';
  20. import { isInBreakoutRoom } from '../../../breakout-rooms/functions';
  21. /**
  22. * Menu presenting options to leave a room or meeting and to end meeting.
  23. *
  24. * @returns {JSX.Element} - The hangup menu.
  25. */
  26. function HangupMenu() {
  27. const dispatch = useDispatch();
  28. const _styles: any = useSelector((state: IReduxState) => ColorSchemeRegistry.get(state, 'Toolbox'));
  29. const inBreakoutRoom = useSelector(isInBreakoutRoom);
  30. const isModerator = useSelector((state: IReduxState) =>
  31. getLocalParticipant(state)?.role === PARTICIPANT_ROLE.MODERATOR);
  32. const { DESTRUCTIVE, SECONDARY } = BUTTON_TYPES;
  33. const handleEndConference = useCallback(() => {
  34. dispatch(hideSheet());
  35. sendAnalytics(createToolbarEvent('endmeeting'));
  36. dispatch(endConference());
  37. dispatch(appNavigate(undefined));
  38. }, [ hideSheet ]);
  39. const handleLeaveConference = useCallback(() => {
  40. dispatch(hideSheet());
  41. sendAnalytics(createToolbarEvent('hangup'));
  42. dispatch(appNavigate(undefined));
  43. }, [ hideSheet ]);
  44. const handleLeaveBreakoutRoom = useCallback(() => {
  45. dispatch(hideSheet());
  46. sendAnalytics(createBreakoutRoomsEvent('leave'));
  47. dispatch(moveToRoom());
  48. }, [ hideSheet ]);
  49. return (
  50. <BottomSheet>
  51. <View style = { _styles.hangupMenuContainer }>
  52. { isModerator && <Button
  53. accessibilityLabel = 'toolbar.endConference'
  54. labelKey = 'toolbar.endConference'
  55. onClick = { handleEndConference }
  56. style = { _styles.hangupButton }
  57. type = { DESTRUCTIVE } /> }
  58. <Button
  59. accessibilityLabel = 'toolbar.leaveConference'
  60. labelKey = 'toolbar.leaveConference'
  61. onClick = { handleLeaveConference }
  62. style = { _styles.hangupButton }
  63. type = { SECONDARY } />
  64. { inBreakoutRoom && <Button
  65. accessibilityLabel = 'breakoutRooms.actions.leaveBreakoutRoom'
  66. labelKey = 'breakoutRooms.actions.leaveBreakoutRoom'
  67. onClick = { handleLeaveBreakoutRoom }
  68. style = { _styles.hangupButton }
  69. type = { SECONDARY } /> }
  70. </View>
  71. </BottomSheet>
  72. );
  73. }
  74. export default HangupMenu;