Merge pull request #540 from damencho/fix-etherpad

Fix etherpad
This commit is contained in:
yanas 2016-03-17 22:37:00 -05:00
commit eec8129026
4 changed files with 37 additions and 5 deletions

View File

@ -52,7 +52,7 @@ const DEFAULT_WIDTH = 640;
*/
const DEFAULT_HEIGHT = 480;
const EtherpadContainerType = "etherpad";
const ETHERPAD_CONTAINER_TYPE = "etherpad";
/**
* Container for Etherpad iframe.
@ -133,6 +133,13 @@ class Etherpad extends LargeContainer {
});
});
}
/**
* @return {boolean} do not switch on dominant speaker event if on stage.
*/
stayOnStage () {
return true;
}
}
/**
@ -159,7 +166,7 @@ export default class EtherpadManager {
openEtherpad () {
this.etherpad = new Etherpad(this.domain, this.name);
VideoLayout.addLargeVideoContainer(
EtherpadContainerType,
ETHERPAD_CONTAINER_TYPE,
this.etherpad
);
}
@ -174,9 +181,10 @@ export default class EtherpadManager {
}
let isVisible = VideoLayout.isLargeContainerTypeVisible(
EtherpadContainerType
ETHERPAD_CONTAINER_TYPE
);
VideoLayout.showLargeVideoContainer(EtherpadContainerType, !isVisible);
VideoLayout.showLargeVideoContainer(
ETHERPAD_CONTAINER_TYPE, !isVisible);
}
}

View File

@ -54,4 +54,11 @@ export default class LargeContainer {
showAvatar (show) {
}
/**
* Whether current container needs to be switched on dominant speaker event
* when the container is on stage.
* @return {boolean}
*/
stayOnStage () {
}
}

View File

@ -349,6 +349,13 @@ class VideoContainer extends LargeContainer {
});
});
}
/**
* @return {boolean} switch on dominant speaker event if on stage.
*/
stayOnStage () {
return false;
}
}
/**

View File

@ -524,7 +524,9 @@ var VideoLayout = {
// since we don't want to switch to local video.
// Update the large video if the video source is already available,
// otherwise wait for the "videoactive.jingle" event.
if (!focusedVideoResourceJid && remoteVideo.hasVideoStarted()) {
if (!focusedVideoResourceJid
&& remoteVideo.hasVideoStarted()
&& !this.getCurrentlyOnLargeContainer().stayOnStage()) {
this.updateLargeVideo(id);
}
},
@ -889,6 +891,14 @@ var VideoLayout = {
return this.isLargeContainerTypeVisible(VideoContainerType);
},
/**
* @return {LargeContainer} the currently displayed container on large
* video.
*/
getCurrentlyOnLargeContainer () {
return largeVideo.getContainer(largeVideo.state);
},
isCurrentlyOnLarge (id) {
return largeVideo && largeVideo.id === id;
},