import React, { useContext } from 'react'; import { Meteor } from 'meteor/meteor'; import { withTracker } from 'meteor/react-meteor-data'; import { injectIntl } from 'react-intl'; import { useSubscription, useMutation } from '@apollo/client'; import getFromUserSettings from '/imports/ui/services/users-settings'; import Auth from '/imports/ui/services/auth'; import ActionsBar from './component'; import { layoutSelectOutput, layoutDispatch } from '../layout/context'; import { isExternalVideoEnabled, isPollingEnabled, isPresentationEnabled, isTimerFeatureEnabled } from '/imports/ui/services/features'; import { isScreenBroadcasting, isCameraAsContentBroadcasting, useIsSharing, useSharingContentType } from '/imports/ui/components/screenshare/service'; import { PluginsContext } from '/imports/ui/components/components-data/plugin-context/context'; import { CURRENT_PRESENTATION_PAGE_SUBSCRIPTION, } from '/imports/ui/components/whiteboard/queries'; import MediaService from '../media/service'; import useMeeting from '/imports/ui/core/hooks/useMeeting'; import useCurrentUser from '/imports/ui/core/hooks/useCurrentUser'; import { EXTERNAL_VIDEO_STOP } from '../external-video-player/mutations'; import { PINNED_PAD_SUBSCRIPTION } from '../notes/queries'; const ActionsBarContainer = (props) => { const NOTES_CONFIG = window.meetingClientSettings.public.notes; const RAISE_HAND_BUTTON_ENABLED = window.meetingClientSettings .public.app.raiseHandActionButton.enabled; const RAISE_HAND_BUTTON_CENTERED = window.meetingClientSettings .public.app.raiseHandActionButton.centered; const actionsBarStyle = layoutSelectOutput((i) => i.actionBar); const layoutContextDispatch = layoutDispatch(); const { data: presentationPageData } = useSubscription(CURRENT_PRESENTATION_PAGE_SUBSCRIPTION); const presentationPage = presentationPageData?.pres_page_curr[0] || {}; const isThereCurrentPresentation = !!presentationPage?.presentationId; const { data: currentMeeting } = useMeeting((m) => ({ externalVideo: m.externalVideo, componentsFlags: m.componentsFlags, })); const isSharingVideo = !!currentMeeting?.externalVideo?.externalVideoUrl; const { pluginsExtensibleAreasAggregatedState, } = useContext(PluginsContext); let actionBarItems = []; if (pluginsExtensibleAreasAggregatedState.actionsBarItems) { actionBarItems = [ ...pluginsExtensibleAreasAggregatedState.actionsBarItems, ]; } const { data: currentUserData } = useCurrentUser((user) => ({ presenter: user.presenter, emoji: user.emoji, isModerator: user.isModerator, })); const [stopExternalVideoShare] = useMutation(EXTERNAL_VIDEO_STOP); const currentUser = { userId: Auth.userID, emoji: currentUserData?.emoji, }; const amIPresenter = currentUserData?.presenter; const amIModerator = currentUserData?.isModerator; const { data: pinnedPadData } = useSubscription(PINNED_PAD_SUBSCRIPTION); const isSharedNotesPinnedFromGraphql = !!pinnedPadData && pinnedPadData.sharedNotes[0]?.sharedNotesExtId === NOTES_CONFIG.id; const isSharedNotesPinned = isSharedNotesPinnedFromGraphql; if (actionsBarStyle.display === false) return null; if (!currentMeeting) return null; return ( ); }; const isReactionsButtonEnabled = () => { const USER_REACTIONS_ENABLED = window.meetingClientSettings.public.userReaction.enabled; const REACTIONS_BUTTON_ENABLED = window.meetingClientSettings.public.app.reactionsButton.enabled; return USER_REACTIONS_ENABLED && REACTIONS_BUTTON_ENABLED; }; const ActionsBarTracker = withTracker(({ isSharing, sharingContentType }) => ({ enableVideo: getFromUserSettings('bbb_enable_video', window.meetingClientSettings.public.kurento.enableVideo), setPresentationIsOpen: MediaService.setPresentationIsOpen, hasScreenshare: isScreenBroadcasting(isSharing, sharingContentType), hasCameraAsContent: isCameraAsContentBroadcasting(isSharing, sharingContentType), isMeteorConnected: Meteor.status().connected, isPollingEnabled: isPollingEnabled() && isPresentationEnabled(), isReactionsButtonEnabled: isReactionsButtonEnabled(), allowExternalVideo: isExternalVideoEnabled(), }))(injectIntl(ActionsBarContainer)); // TODO: Remove this // Temporary component until we remove all trackers export default (props) => { const isSharing = useIsSharing(); const sharingContentType = useSharingContentType(); return ( ); };