bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/breakout-join-confirmation/container.jsx
2021-08-04 14:32:11 +00:00

46 lines
1.4 KiB
JavaScript
Executable File

import React from 'react';
import { withTracker } from 'meteor/react-meteor-data';
import Breakouts from '/imports/api/breakouts';
import Auth from '/imports/ui/services/auth';
import { makeCall } from '/imports/ui/services/api';
import breakoutService from '/imports/ui/components/breakout-room/service';
import AudioManager from '/imports/ui/services/audio-manager';
import BreakoutJoinConfirmationComponent from './component';
const BreakoutJoinConfirmationContrainer = (props) => (
<BreakoutJoinConfirmationComponent
{...props}
/>
);
const getURL = (breakoutId) => {
const currentUserId = Auth.userID;
const getBreakout = Breakouts.findOne({ breakoutId }, { fields: { users: 1 } });
const user = getBreakout ? getBreakout.users?.find((u) => u.userId === currentUserId) : '';
if (user) return user.redirectToHtml5JoinURL;
return '';
};
const requestJoinURL = (breakoutId) => {
makeCall('requestJoinURL', {
breakoutId,
});
};
export default withTracker(({ breakout, mountModal, breakoutName }) => {
const isFreeJoin = breakout.freeJoin;
const { breakoutId } = breakout;
const url = getURL(breakoutId);
return {
isFreeJoin,
mountModal,
breakoutName,
breakoutURL: url,
breakouts: breakoutService.getBreakouts(),
requestJoinURL,
getURL,
voiceUserJoined: AudioManager.isUsingAudio(),
};
})(BreakoutJoinConfirmationContrainer);