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

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