forked from External/greenlight
237 lines
9.0 KiB
JavaScript
237 lines
9.0 KiB
JavaScript
// BigBlueButton open source conferencing system - http://www.bigbluebutton.org/.
|
|
//
|
|
// Copyright (c) 2016 BigBlueButton Inc. and by respective authors (see below).
|
|
//
|
|
// This program is free software; you can redistribute it and/or modify it under the
|
|
// terms of the GNU Lesser General Public License as published by the Free Software
|
|
// Foundation; either version 3.0 of the License, or (at your option) any later
|
|
// version.
|
|
//
|
|
// BigBlueButton is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
// WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
// PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public License along
|
|
// with BigBlueButton; if not, see <http://www.gnu.org/licenses/>.
|
|
|
|
// Handles live updating and initial population of the previous meetings and active meetings lists on
|
|
// the landing page using custom Actioncable events.
|
|
|
|
var MEETINGS = {}
|
|
var WAITING = {}
|
|
var LOADING_DELAY = 1750 // milliseconds.
|
|
|
|
// Updates the previous meetings section.
|
|
var updatePreviousMeetings = function(){
|
|
$("ul.previously-joined li").each(function(idx, li) {
|
|
var previous_meeting = $(li);
|
|
if(Object.keys(MEETINGS).indexOf(previous_meeting.text()) > -1){
|
|
previous_meeting.remove()
|
|
}
|
|
});
|
|
}
|
|
|
|
// Ignore excess on either side of user_id.
|
|
var trimUserId = function(user_id){
|
|
components = user_id.split('_')
|
|
return components.sort(function (a, b) {return b.length - a.length;})[0]
|
|
}
|
|
|
|
// Finds a user by their user_id.
|
|
var findByUserId = function(users, user_id){
|
|
for(i = 0; i < users.length; i++){
|
|
if(trimUserId(users[i]['user_id']) == trimUserId(user_id)){
|
|
return i
|
|
}
|
|
}
|
|
return undefined
|
|
}
|
|
|
|
// Adds a user to a meeting.
|
|
var addUser = function(data){
|
|
if(data['role'] == 'MODERATOR'){
|
|
MEETINGS[data['meeting']]['moderators'].push({'name': data['user'], 'user_id': data['user_id']})
|
|
} else {
|
|
MEETINGS[data['meeting']]['participants'].push({'name':data['user'], 'user_id': data['user_id']})
|
|
}
|
|
updateMeetingText(MEETINGS[data['meeting']])
|
|
}
|
|
|
|
// Removes a user from a meeting.
|
|
var removeUser = function(data){
|
|
user = findByUserId(MEETINGS[data['meeting']]['moderators'], data['user_id'])
|
|
if(user == undefined){
|
|
user = findByUserId(MEETINGS[data['meeting']]['participants'], data['user_id']);
|
|
if(user == undefined){ return; }
|
|
MEETINGS[data['meeting']]['participants'].splice(user, 1);
|
|
} else {
|
|
MEETINGS[data['meeting']]['moderators'].splice(user, 1);
|
|
}
|
|
updateMeetingText(MEETINGS[data['meeting']])
|
|
}
|
|
|
|
// Updates the display text for an active meeting.
|
|
var updateMeetingText = function(m){
|
|
// If a meeting has a moderators property, it is running.
|
|
var body;
|
|
if(m.hasOwnProperty('moderators')){
|
|
var list;
|
|
if(m['moderators'].length + m['participants'].length == 0){
|
|
list = '(empty)'
|
|
} else {
|
|
list = m['moderators'].map(function(x){ return x['name']; }).join('(mod), ') +
|
|
(m['moderators'].length > 0 ? '(mod)' : '') +
|
|
(m['participants'].length > 0 && m['moderators'].length != 0 ? ', ' : '') +
|
|
(m['participants'].map(function(x){ return x['name']; }).join(', '))
|
|
}
|
|
body = '<a>' + m['name'] + '</a><i>: ' + list + '</i>'
|
|
// Otherwise it hasn't started (users waiting the join).
|
|
} else {
|
|
body = '<a>' + m['name'] + '</a><i> (not yet started): ' + m['users'].join(', ') + '</i>'
|
|
}
|
|
|
|
// If the item doesn't exist, add it and set up join meeting event.
|
|
if($("li[id='" + m['name'].replace(' ', '_') + "']").length == 0){
|
|
var meeting_item = $("<li>" + body + "</li>")
|
|
meeting_item.attr('id', m['name'].replace(' ', '_'))
|
|
$('.actives').append(meeting_item);
|
|
|
|
// Set up join on click.
|
|
meeting_item.click(function(){
|
|
joinMeeting(m['name']);
|
|
});
|
|
// Otherwise, just change the body.
|
|
} else {
|
|
$("li[id='" + m['name'].replace(' ', '_') + "']").html(body)
|
|
}
|
|
}
|
|
|
|
// Initially populates the active meetings when the page loads using the API.
|
|
var initialPopulate = function(){
|
|
// Only populate on room resources.
|
|
var chopped = window.location.href.split('/')
|
|
if (!window.location.href.includes('rooms') || chopped[chopped.length - 2] == $('body').data('current-user')) { return; }
|
|
|
|
$.post((window.location.href + '/statuses').replace('#', ''), {previously_joined: getPreviouslyJoined()})
|
|
.done(function(data) {
|
|
|
|
// Populate waiting meetings.
|
|
Object.keys(data['waiting']).forEach(function(key) {
|
|
WAITING[key] = {'name': key, 'users': data['waiting'][key]}
|
|
updateMeetingText(WAITING[key])
|
|
})
|
|
|
|
// Add the meetings to the active meetings list.
|
|
for(var i = 0; i < data['active'].length; i++){
|
|
var meeting = data['active'][i]
|
|
|
|
var name = meeting['name']
|
|
var participants = meeting['participants']
|
|
var moderators = meeting['moderators']
|
|
|
|
// Create meeting.
|
|
MEETINGS[name] = {'name': name, 'participants': participants, 'moderators': moderators}
|
|
updateMeetingText(MEETINGS[name])
|
|
}
|
|
|
|
// Remove from previous meetings if they are active.
|
|
updatePreviousMeetings();
|
|
$('.hidden-list').show();
|
|
$('.active-spinner').hide();
|
|
});
|
|
}
|
|
|
|
// Gets a list of known previously joined meetings.
|
|
var getPreviouslyJoined = function(){
|
|
var joinedMeetings = localStorage.getItem('joinedRooms-' + $('body').data('current-user'));
|
|
if (joinedMeetings == '' || joinedMeetings == null){ return []; }
|
|
return joinedMeetings.split(',')
|
|
}
|
|
|
|
// Removes an active meeting.
|
|
var removeActiveMeeting = function(meeting){
|
|
if(meeting){ $("li[id='" + meeting['name'].replace(' ', '_') + "']").remove() }
|
|
}
|
|
|
|
// Directly join a meeting from active meetings.
|
|
var joinMeeting = function(meeting_name){
|
|
if (meeting_name == undefined || meeting_name == null) { return; }
|
|
Meeting.getInstance().setUserName(localStorage.getItem('lastJoinedName'));
|
|
Meeting.getInstance().setMeetingId(meeting_name);
|
|
|
|
var jqxhr = Meeting.getInstance().getJoinMeetingResponse();
|
|
if (jqxhr) {
|
|
jqxhr.done(function(data) {
|
|
if (data.messageKey === 'wait_for_moderator') {
|
|
waitForModerator(Meeting.getInstance().getURL());
|
|
} else {
|
|
$(location).attr("href", data.response.join_url);
|
|
}
|
|
});
|
|
jqxhr.fail(function() {
|
|
console.info("meeting join failed");
|
|
});
|
|
} else {
|
|
$('.meeting-user-name').parent().addClass('has-error');
|
|
}
|
|
}
|
|
|
|
// Only need to register for logged in users.
|
|
$(document).on('turbolinks:load', function(){
|
|
if($('body').data('current-user')){
|
|
MEETINGS = {}
|
|
// Ensure actives is empty.
|
|
$('.actives').empty();
|
|
|
|
if(!App.messages){
|
|
// Setup actioncable.
|
|
App.messages = App.cable.subscriptions.create('RefreshMeetingsChannel', {
|
|
received: function(data) {
|
|
console.log('Recieved ' + data['method'] + ' action for ' + data['meeting'] + ' with room id ' + data['room'] + '.')
|
|
if(data['room'] == $('body').data('current-user')){
|
|
// Handle webhook event.
|
|
if(data['method'] == 'create'){
|
|
// Create an empty meeting.
|
|
MEETINGS[data['meeting']] = {'name': data['meeting'],
|
|
'participants': [],
|
|
'moderators': []}
|
|
updateMeetingText(MEETINGS[data['meeting']])
|
|
updatePreviousMeetings();
|
|
if (WAITING.hasOwnProperty(data['meeting'])){ delete WAITING[data['meeting']]; }
|
|
} else if(data['method'] == 'destroy'){
|
|
removeActiveMeeting(MEETINGS[data['meeting']])
|
|
PreviousMeetings.uniqueAdd([data['meeting']])
|
|
delete MEETINGS[data['meeting']]
|
|
} else if(data['method'] == 'join'){
|
|
addUser(data)
|
|
} else if(data['method'] == 'leave'){
|
|
removeUser(data)
|
|
} else if(data['method'] == 'waiting'){
|
|
// Handle waiting meeting.
|
|
if(WAITING.hasOwnProperty(data['meeting'])){
|
|
WAITING[data['meeting']]['users'].push(data['user'])
|
|
updateMeetingText(WAITING[data['meeting']])
|
|
} else {
|
|
WAITING[data['meeting']] = {'name': data['meeting'],
|
|
'users': [data['user']]}
|
|
updateMeetingText(WAITING[data['meeting']])
|
|
}
|
|
} else if((data['method'] == 'no_longer_waiting') && (WAITING.hasOwnProperty(data['meeting']))){
|
|
WAITING[data['meeting']]['users'].splice(WAITING[data['meeting']]['users'].indexOf(data['user']), 1)
|
|
updateMeetingText(WAITING[data['meeting']])
|
|
if(WAITING[data['meeting']]['users'].length == 0){
|
|
removeActiveMeeting(WAITING[data['meeting']])
|
|
delete WAITING[data['meeting']]
|
|
}
|
|
}
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
console.log('Populating active meetings.');
|
|
// Short delay to hide the previous meetings population.
|
|
setTimeout(initialPopulate, LOADING_DELAY);
|
|
}
|
|
});
|