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.3KB

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