bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/breakout-room/service.js

114 lines
3.2 KiB
JavaScript
Raw Normal View History

2018-10-24 01:18:09 +08:00
import Breakouts from '/imports/api/breakouts';
import Meetings from '/imports/api/meetings';
import { makeCall } from '/imports/ui/services/api';
import Auth from '/imports/ui/services/auth';
2018-10-26 23:16:29 +08:00
import { Session } from 'meteor/session';
2018-10-24 01:18:09 +08:00
import Users from '/imports/api/users';
import mapUser from '/imports/ui/services/user/mapUser';
import fp from 'lodash/fp';
2018-10-24 01:18:09 +08:00
const findBreakouts = () => {
2018-11-02 01:55:35 +08:00
const BreakoutRooms = Breakouts.find({
parentMeetingId: Auth.meetingID,
}, {
sort: {
sequence: 1,
},
}).fetch();
2018-10-24 01:18:09 +08:00
return BreakoutRooms;
};
const breakoutRoomUser = (breakoutId) => {
const breakoutRooms = findBreakouts();
2018-10-24 01:18:09 +08:00
const breakoutRoom = breakoutRooms.filter(breakout => breakout.breakoutId === breakoutId).shift();
const breakoutUser = breakoutRoom.users.filter(user => user.userId === Auth.userID).shift();
return breakoutUser;
};
2018-12-18 23:15:51 +08:00
const closeBreakoutPanel = () => Session.set('openPanel', 'userlist');
2018-10-24 01:18:09 +08:00
const endAllBreakouts = () => {
makeCall('endAllBreakouts');
2018-11-20 07:29:48 +08:00
closeBreakoutPanel();
2018-10-24 01:18:09 +08:00
};
const requestJoinURL = (breakoutId) => {
makeCall('requestJoinURL', {
breakoutId,
});
};
const transferUserToMeeting = (fromMeetingId, toMeetingId) => makeCall('transferUser', fromMeetingId, toMeetingId);
const transferToBreakout = (breakoutId) => {
const breakoutRooms = findBreakouts();
2018-10-24 01:18:09 +08:00
const breakoutRoom = breakoutRooms.filter(breakout => breakout.breakoutId === breakoutId).shift();
const breakoutMeeting = Meetings.findOne({
$and: [
{ 'breakoutProps.sequence': breakoutRoom.sequence },
{ 'breakoutProps.parentId': breakoutRoom.parentMeetingId },
{ 'meetingProp.isBreakout': true },
],
});
transferUserToMeeting(Auth.meetingID, breakoutMeeting.meetingId);
2018-10-24 01:18:09 +08:00
};
const isPresenter = () => {
const User = Users.findOne({ intId: Auth.userID });
const mappedUser = mapUser(User);
return mappedUser.isPresenter;
};
2018-11-02 01:55:35 +08:00
const isModerator = () => {
const User = Users.findOne({ intId: Auth.userID });
const mappedUser = mapUser(User);
return mappedUser.isModerator;
};
2019-04-24 20:50:45 +08:00
const getUsersByBreakoutId = breakoutId => Users.find({
meetingId: breakoutId,
connectionStatus: 'online',
});
const getBreakoutByUserId = userId => Breakouts.find({ 'users.userId': userId }).fetch();
const getBreakoutByUser = user => Breakouts.findOne({ users: user });
const getUsersFromBreakouts = breakoutsArray => breakoutsArray
.map(breakout => breakout.users)
.reduce((acc, usersArray) => [...acc, ...usersArray], []);
const filterUserURLs = userId => breakoutUsersArray => breakoutUsersArray
.filter(user => user.userId === userId);
const getLastURLInserted = breakoutURLArray => breakoutURLArray
.sort((a, b) => a.insertedTime - b.insertedTime).pop();
const getBreakoutUserByUserId = userId => fp.pipe(
getBreakoutByUserId,
getUsersFromBreakouts,
filterUserURLs(userId),
getLastURLInserted,
)(userId);
const getBreakouts = () => Breakouts.find({}, { sort: { sequence: 1 } }).fetch();
2019-04-24 20:50:45 +08:00
2018-10-24 01:18:09 +08:00
export default {
findBreakouts,
2018-10-24 01:18:09 +08:00
endAllBreakouts,
requestJoinURL,
breakoutRoomUser,
transferUserToMeeting,
transferToBreakout,
meetingId: () => Auth.meetingID,
2018-10-24 01:18:09 +08:00
isPresenter,
2018-10-26 23:16:29 +08:00
closeBreakoutPanel,
2018-11-02 01:55:35 +08:00
isModerator,
2019-04-24 20:50:45 +08:00
getUsersByBreakoutId,
getBreakoutUserByUserId,
getBreakoutByUser,
getBreakouts,
getBreakoutByUserId,
2018-10-24 01:18:09 +08:00
};