Fixes issues for audio only participants

This commit is contained in:
hristoterezov 2016-01-29 13:31:58 -06:00
parent 4e66aefa26
commit 1176390214
3 changed files with 19 additions and 9 deletions

View File

@ -225,7 +225,9 @@ export default {
return JitsiMeetJS.init(config).then(() => {
return Promise.all([
this.createLocalTracks('audio', 'video').catch(
this.createLocalTracks('audio', 'video').catch(()=>{
return this.createLocalTracks('audio');
}).catch(
() => {return [];}),
connect()
]);
@ -500,7 +502,7 @@ export default {
handler(id , mute);
});
room.on(ConferenceEvents.TRACK_AUDIO_LEVEL_CHANGED, (id, lvl) => {
if(this.isLocalId(id) && localAudio.isMuted()) {
if(this.isLocalId(id) && localAudio && localAudio.isMuted()) {
lvl = 0;
}
@ -584,9 +586,13 @@ export default {
});
APP.UI.addListener(UIEvents.AUDIO_MUTED, (muted) => {
if(!localAudio)
return;
(muted)? localAudio.mute() : localAudio.unmute();
});
APP.UI.addListener(UIEvents.VIDEO_MUTED, (muted) => {
if(!localVideo)
return;
(muted)? localVideo.mute() : localVideo.unmute();
});
@ -794,7 +800,7 @@ export default {
APP.desktopsharing.addListener(DSEvents.NEW_STREAM_CREATED,
(track, callback) => {
const localCallback = (newTrack) => {
if(!newTrack || !newTrack.isLocal() ||
if(!newTrack || !localVideo || !newTrack.isLocal() ||
newTrack !== localVideo)
return;
if(localVideo.isMuted() &&
@ -808,7 +814,8 @@ export default {
if(room) {
room.on(ConferenceEvents.TRACK_ADDED, localCallback);
}
localVideo.stop();
if(localVideo)
localVideo.stop();
localVideo = track;
addTrack(track);
if(!room)

View File

@ -277,6 +277,9 @@ class VideoContainer extends LargeContainer {
this.stream = stream;
this.videoType = videoType;
if(!stream)
return;
stream.attach(this.$video);
let flipX = stream.isLocal() && !this.isScreenSharing();
@ -421,7 +424,7 @@ export default class LargeVideoManager {
// change the avatar url on large
this.updateAvatar(Avatar.getAvatarUrl(id));
let isVideoMuted = stream.isMuted();
let isVideoMuted = stream? stream.isMuted() : true;
// show the avatar on large if needed
this.videoContainer.showAvatar(isVideoMuted);
@ -443,19 +446,18 @@ export default class LargeVideoManager {
/**
* Update large video.
* Switches to large video even if previously other container was visible.
* @param userID the userID of the participant associated with the stream
* @param {JitsiTrack?} stream new stream
* @param {string?} videoType new video type
* @returns {Promise}
*/
updateLargeVideo (stream, videoType) {
let id = getStreamOwnerId(stream);
updateLargeVideo (userID, stream, videoType) {
if (this.newStreamData) {
this.newStreamData.reject();
}
this.newStreamData = createDeferred();
this.newStreamData.id = id;
this.newStreamData.id = userID;
this.newStreamData.stream = stream;
this.newStreamData.videoType = videoType;

View File

@ -987,6 +987,7 @@ var VideoLayout = {
let videoType = this.getRemoteVideoType(id);
largeVideo.updateLargeVideo(
id,
smallVideo.videoStream,
videoType
).then(function() {