Fixes issues for audio only participants
This commit is contained in:
parent
4e66aefa26
commit
1176390214
|
@ -225,7 +225,9 @@ export default {
|
||||||
|
|
||||||
return JitsiMeetJS.init(config).then(() => {
|
return JitsiMeetJS.init(config).then(() => {
|
||||||
return Promise.all([
|
return Promise.all([
|
||||||
this.createLocalTracks('audio', 'video').catch(
|
this.createLocalTracks('audio', 'video').catch(()=>{
|
||||||
|
return this.createLocalTracks('audio');
|
||||||
|
}).catch(
|
||||||
() => {return [];}),
|
() => {return [];}),
|
||||||
connect()
|
connect()
|
||||||
]);
|
]);
|
||||||
|
@ -500,7 +502,7 @@ export default {
|
||||||
handler(id , mute);
|
handler(id , mute);
|
||||||
});
|
});
|
||||||
room.on(ConferenceEvents.TRACK_AUDIO_LEVEL_CHANGED, (id, lvl) => {
|
room.on(ConferenceEvents.TRACK_AUDIO_LEVEL_CHANGED, (id, lvl) => {
|
||||||
if(this.isLocalId(id) && localAudio.isMuted()) {
|
if(this.isLocalId(id) && localAudio && localAudio.isMuted()) {
|
||||||
lvl = 0;
|
lvl = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -584,9 +586,13 @@ export default {
|
||||||
});
|
});
|
||||||
|
|
||||||
APP.UI.addListener(UIEvents.AUDIO_MUTED, (muted) => {
|
APP.UI.addListener(UIEvents.AUDIO_MUTED, (muted) => {
|
||||||
|
if(!localAudio)
|
||||||
|
return;
|
||||||
(muted)? localAudio.mute() : localAudio.unmute();
|
(muted)? localAudio.mute() : localAudio.unmute();
|
||||||
});
|
});
|
||||||
APP.UI.addListener(UIEvents.VIDEO_MUTED, (muted) => {
|
APP.UI.addListener(UIEvents.VIDEO_MUTED, (muted) => {
|
||||||
|
if(!localVideo)
|
||||||
|
return;
|
||||||
(muted)? localVideo.mute() : localVideo.unmute();
|
(muted)? localVideo.mute() : localVideo.unmute();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -794,7 +800,7 @@ export default {
|
||||||
APP.desktopsharing.addListener(DSEvents.NEW_STREAM_CREATED,
|
APP.desktopsharing.addListener(DSEvents.NEW_STREAM_CREATED,
|
||||||
(track, callback) => {
|
(track, callback) => {
|
||||||
const localCallback = (newTrack) => {
|
const localCallback = (newTrack) => {
|
||||||
if(!newTrack || !newTrack.isLocal() ||
|
if(!newTrack || !localVideo || !newTrack.isLocal() ||
|
||||||
newTrack !== localVideo)
|
newTrack !== localVideo)
|
||||||
return;
|
return;
|
||||||
if(localVideo.isMuted() &&
|
if(localVideo.isMuted() &&
|
||||||
|
@ -808,7 +814,8 @@ export default {
|
||||||
if(room) {
|
if(room) {
|
||||||
room.on(ConferenceEvents.TRACK_ADDED, localCallback);
|
room.on(ConferenceEvents.TRACK_ADDED, localCallback);
|
||||||
}
|
}
|
||||||
localVideo.stop();
|
if(localVideo)
|
||||||
|
localVideo.stop();
|
||||||
localVideo = track;
|
localVideo = track;
|
||||||
addTrack(track);
|
addTrack(track);
|
||||||
if(!room)
|
if(!room)
|
||||||
|
|
|
@ -277,6 +277,9 @@ class VideoContainer extends LargeContainer {
|
||||||
this.stream = stream;
|
this.stream = stream;
|
||||||
this.videoType = videoType;
|
this.videoType = videoType;
|
||||||
|
|
||||||
|
if(!stream)
|
||||||
|
return;
|
||||||
|
|
||||||
stream.attach(this.$video);
|
stream.attach(this.$video);
|
||||||
|
|
||||||
let flipX = stream.isLocal() && !this.isScreenSharing();
|
let flipX = stream.isLocal() && !this.isScreenSharing();
|
||||||
|
@ -421,7 +424,7 @@ export default class LargeVideoManager {
|
||||||
// change the avatar url on large
|
// change the avatar url on large
|
||||||
this.updateAvatar(Avatar.getAvatarUrl(id));
|
this.updateAvatar(Avatar.getAvatarUrl(id));
|
||||||
|
|
||||||
let isVideoMuted = stream.isMuted();
|
let isVideoMuted = stream? stream.isMuted() : true;
|
||||||
|
|
||||||
// show the avatar on large if needed
|
// show the avatar on large if needed
|
||||||
this.videoContainer.showAvatar(isVideoMuted);
|
this.videoContainer.showAvatar(isVideoMuted);
|
||||||
|
@ -443,19 +446,18 @@ export default class LargeVideoManager {
|
||||||
/**
|
/**
|
||||||
* Update large video.
|
* Update large video.
|
||||||
* Switches to large video even if previously other container was visible.
|
* 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 {JitsiTrack?} stream new stream
|
||||||
* @param {string?} videoType new video type
|
* @param {string?} videoType new video type
|
||||||
* @returns {Promise}
|
* @returns {Promise}
|
||||||
*/
|
*/
|
||||||
updateLargeVideo (stream, videoType) {
|
updateLargeVideo (userID, stream, videoType) {
|
||||||
let id = getStreamOwnerId(stream);
|
|
||||||
|
|
||||||
if (this.newStreamData) {
|
if (this.newStreamData) {
|
||||||
this.newStreamData.reject();
|
this.newStreamData.reject();
|
||||||
}
|
}
|
||||||
|
|
||||||
this.newStreamData = createDeferred();
|
this.newStreamData = createDeferred();
|
||||||
this.newStreamData.id = id;
|
this.newStreamData.id = userID;
|
||||||
this.newStreamData.stream = stream;
|
this.newStreamData.stream = stream;
|
||||||
this.newStreamData.videoType = videoType;
|
this.newStreamData.videoType = videoType;
|
||||||
|
|
||||||
|
|
|
@ -987,6 +987,7 @@ var VideoLayout = {
|
||||||
|
|
||||||
let videoType = this.getRemoteVideoType(id);
|
let videoType = this.getRemoteVideoType(id);
|
||||||
largeVideo.updateLargeVideo(
|
largeVideo.updateLargeVideo(
|
||||||
|
id,
|
||||||
smallVideo.videoStream,
|
smallVideo.videoStream,
|
||||||
videoType
|
videoType
|
||||||
).then(function() {
|
).then(function() {
|
||||||
|
|
Loading…
Reference in New Issue