bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/actions-bar/container.jsx
2018-10-25 22:41:45 +00:00

41 lines
1.6 KiB
JavaScript

import React from 'react';
import { withTracker } from 'meteor/react-meteor-data';
import { Session } from 'meteor/session';
import getFromUserSettings from '/imports/ui/services/users-settings';
import ActionsBar from './component';
import Service from './service';
import VideoService from '../video-provider/service';
import { shareScreen, unshareScreen, isVideoBroadcasting } from '../screenshare/service';
import { withRouter } from 'react-router';
const ActionsBarContainer = props => <ActionsBar {...props} />;
export default withRouter(withTracker(({ }) => {
const togglePollMenu = () => {
const showPoll = Session.equals('isPollOpen', false) || !Session.get('isPollOpen');
const show = () => Session.set('isPollOpen', true);
const hide = () => Session.set('isPollOpen', false);
if (Session.equals('isChatOpen', true)) Session.set('isChatOpen', false);
return showPoll ? show() : hide();
};
return {
isUserPresenter: Service.isUserPresenter(),
isUserModerator: Service.isUserModerator(),
handleExitVideo: () => VideoService.exitVideo(),
handleJoinVideo: () => VideoService.joinVideo(),
handleShareScreen: onFail => shareScreen(onFail),
handleUnshareScreen: () => unshareScreen(),
isVideoBroadcasting: isVideoBroadcasting(),
recordSettingsList: Service.recordSettingsList(),
toggleRecording: Service.toggleRecording,
screenSharingCheck: getFromUserSettings('enableScreensharing', Meteor.settings.public.kurento.enableScreensharing),
enableVideo: getFromUserSettings('enableVideo', Meteor.settings.public.kurento.enableVideo),
togglePollMenu,
};
})(ActionsBarContainer));