bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/lock-viewers/context/container.jsx

31 lines
1.4 KiB
React
Raw Normal View History

2019-05-24 00:47:56 +08:00
import { withTracker } from 'meteor/react-meteor-data';
import Meetings from '/imports/api/meetings';
2019-05-24 00:47:56 +08:00
import Auth from '/imports/ui/services/auth';
import { LockStruct } from './context';
import { withUsersConsumer } from '/imports/ui/components/components-data/users-context/context';
2019-05-24 00:47:56 +08:00
import { withLockContext } from './withContext';
const ROLE_MODERATOR = Meteor.settings.public.user.role_moderator;
2019-05-24 00:47:56 +08:00
const lockContextContainer = component => withUsersConsumer(withTracker(({ users }) => {
const lockSetting = new LockStruct();
const Meeting = Meetings.findOne({ meetingId: Auth.meetingID },
{ fields: { lockSettingsProps: 1 } });
2021-04-15 20:12:21 +08:00
const User = users[Auth.meetingID][Auth.userID];
const userIsLocked = User.locked && User.role !== ROLE_MODERATOR;
2019-05-24 00:47:56 +08:00
const lockSettings = Meeting.lockSettingsProps;
lockSetting.isLocked = userIsLocked;
lockSetting.lockSettings = lockSettings;
lockSetting.userLocks.userWebcam = userIsLocked && lockSettings.disableCam;
lockSetting.userLocks.userMic = userIsLocked && lockSettings.disableMic;
lockSetting.userLocks.userNote = userIsLocked && lockSettings.disableNote;
lockSetting.userLocks.userPrivateChat = userIsLocked && lockSettings.disablePrivateChat;
lockSetting.userLocks.userPublicChat = userIsLocked && lockSettings.disablePublicChat;
lockSetting.userLocks.userLockedLayout = userIsLocked && lockSettings.lockedLayout;
return lockSetting;
})(withLockContext(component)));
2019-05-24 00:47:56 +08:00
export default lockContextContainer;