bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/nav-bar/options-dropdown/container.jsx

80 lines
2.9 KiB
React
Raw Normal View History

import React, { useContext } from 'react';
2019-03-12 00:21:12 +08:00
import { withTracker } from 'meteor/react-meteor-data';
import deviceInfo from '/imports/utils/deviceInfo';
import browserInfo from '/imports/utils/browserInfo';
import OptionsDropdown from './component';
import FullscreenService from '/imports/ui/components/common/fullscreen-button/service';
2019-08-30 00:32:29 +08:00
import { meetingIsBreakout } from '/imports/ui/components/app/service';
2022-05-13 21:42:19 +08:00
import { layoutSelectInput, layoutSelect } from '../../layout/context';
import { SMALL_VIEWPORT_BREAKPOINT } from '../../layout/enums';
import { PluginsContext } from '/imports/ui/components/components-data/plugin-context/context';
2023-12-08 03:40:32 +08:00
import { USER_LEAVE_MEETING } from '/imports/ui/core/graphql/mutations/userMutations';
import { useMutation } from '@apollo/client';
2024-01-30 00:27:30 +08:00
import useMeeting from '/imports/ui/core/hooks/useMeeting';
2024-04-25 04:18:21 +08:00
import { useShortcut } from '/imports/ui/core/hooks/useShortcut';
import { useStorageKey } from '/imports/ui/services/storage/hooks';
import Session from '/imports/ui/services/storage/in-memory';
const { isIphone } = deviceInfo;
const { isSafari, isValidSafariVersion } = browserInfo;
const noIOSFullscreen = !!(((isSafari && !isValidSafariVersion) || isIphone));
2024-04-17 06:39:29 +08:00
const setAudioCaptions = (value) => Session.setItem('audioCaptions', value);
2019-09-05 02:32:58 +08:00
const OptionsDropdownContainer = (props) => {
const { width: browserWidth } = layoutSelectInput((i) => i.browser);
const isMobile = browserWidth <= SMALL_VIEWPORT_BREAKPOINT;
2022-05-13 21:42:19 +08:00
const isRTL = layoutSelect((i) => i.isRTL);
const { pluginsExtensibleAreasAggregatedState } = useContext(PluginsContext);
let optionsDropdownItems = [];
if (pluginsExtensibleAreasAggregatedState.optionsDropdownItems) {
optionsDropdownItems = [
...pluginsExtensibleAreasAggregatedState.optionsDropdownItems,
];
}
2024-01-30 00:27:30 +08:00
const {
data: currentMeeting,
} = useMeeting((m) => ({
componentsFlags: m.componentsFlags,
}));
2024-01-30 00:27:30 +08:00
const componentsFlags = currentMeeting?.componentsFlags;
const audioCaptionsEnabled = componentsFlags?.hasCaption;
2023-12-08 03:40:32 +08:00
const [userLeaveMeeting] = useMutation(USER_LEAVE_MEETING);
2024-04-25 04:18:21 +08:00
const openOptions = useShortcut('openOptions');
const audioCaptionsActive = useStorageKey('audioCaptions') || false;
const isDropdownOpen = useStorageKey('dropdownOpen');
2023-12-08 03:40:32 +08:00
return (
<OptionsDropdown {...{
2024-04-25 04:18:21 +08:00
isMobile,
isRTL,
optionsDropdownItems,
userLeaveMeeting,
audioCaptionsEnabled,
shortcuts: openOptions,
audioCaptionsActive,
isDropdownOpen,
2024-04-25 04:18:21 +08:00
...props,
}}
/>
);
};
2019-03-12 00:21:12 +08:00
export default withTracker((props) => {
2019-07-27 00:48:51 +08:00
const handleToggleFullscreen = () => FullscreenService.toggleFullScreen();
2019-03-12 00:21:12 +08:00
return {
amIModerator: props.amIModerator,
2024-04-17 06:39:29 +08:00
audioCaptionsSet: (value) => setAudioCaptions(value),
isMobile: deviceInfo.isMobile,
2019-03-12 00:21:12 +08:00
handleToggleFullscreen,
noIOSFullscreen,
2019-06-27 00:29:34 +08:00
isMeteorConnected: Meteor.status().connected,
2019-08-30 00:32:29 +08:00
isBreakoutRoom: meetingIsBreakout(),
2019-03-12 00:21:12 +08:00
};
})(OptionsDropdownContainer);