2019-04-17 15:05:32 +00:00
|
|
|
// @flow
|
|
|
|
|
|
|
|
import { getCurrentConference } from '../base/conference';
|
|
|
|
import {
|
|
|
|
getPinnedParticipant,
|
|
|
|
isLocalParticipantModerator
|
|
|
|
} from '../base/participants';
|
2020-05-20 10:57:03 +00:00
|
|
|
import { StateListenerRegistry } from '../base/redux';
|
2019-04-17 15:05:32 +00:00
|
|
|
|
|
|
|
import { FOLLOW_ME_COMMAND } from './constants';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Subscribes to changes to the Follow Me setting for the local participant to
|
|
|
|
* notify remote participants of current user interface status.
|
2019-04-26 18:11:53 +00:00
|
|
|
* Changing newSelectedValue param to off, when feature is turned of so we can
|
|
|
|
* notify all listeners.
|
2019-04-17 15:05:32 +00:00
|
|
|
*/
|
|
|
|
StateListenerRegistry.register(
|
|
|
|
/* selector */ state => state['features/base/conference'].followMeEnabled,
|
2019-04-26 18:11:53 +00:00
|
|
|
/* listener */ (newSelectedValue, store) => _sendFollowMeCommand(newSelectedValue || 'off', store));
|
2019-04-17 15:05:32 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Subscribes to changes to the currently pinned participant in the user
|
|
|
|
* interface of the local participant.
|
|
|
|
*/
|
|
|
|
StateListenerRegistry.register(
|
|
|
|
/* selector */ state => {
|
|
|
|
const pinnedParticipant = getPinnedParticipant(state);
|
|
|
|
|
|
|
|
return pinnedParticipant ? pinnedParticipant.id : null;
|
|
|
|
},
|
|
|
|
/* listener */ _sendFollowMeCommand);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Subscribes to changes to the shared document (etherpad) visibility in the
|
|
|
|
* user interface of the local participant.
|
|
|
|
*
|
|
|
|
* @param sharedDocumentVisible {Boolean} {true} if the shared document was
|
|
|
|
* shown (as a result of the toggle) or {false} if it was hidden
|
|
|
|
*/
|
|
|
|
StateListenerRegistry.register(
|
|
|
|
/* selector */ state => state['features/etherpad'].editing,
|
|
|
|
/* listener */ _sendFollowMeCommand);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Subscribes to changes to the filmstrip visibility in the user interface of
|
|
|
|
* the local participant.
|
|
|
|
*/
|
|
|
|
StateListenerRegistry.register(
|
|
|
|
/* selector */ state => state['features/filmstrip'].visible,
|
|
|
|
/* listener */ _sendFollowMeCommand);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Subscribes to changes to the tile view setting in the user interface of the
|
|
|
|
* local participant.
|
|
|
|
*/
|
|
|
|
StateListenerRegistry.register(
|
|
|
|
/* selector */ state => state['features/video-layout'].tileViewEnabled,
|
|
|
|
/* listener */ _sendFollowMeCommand);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Private selector for returning state from redux that should be respected by
|
|
|
|
* other participants while follow me is enabled.
|
|
|
|
*
|
|
|
|
* @param {Object} state - The redux state.
|
|
|
|
* @returns {Object}
|
|
|
|
*/
|
|
|
|
function _getFollowMeState(state) {
|
|
|
|
const pinnedParticipant = getPinnedParticipant(state);
|
|
|
|
|
|
|
|
return {
|
|
|
|
filmstripVisible: state['features/filmstrip'].visible,
|
|
|
|
nextOnStage: pinnedParticipant && pinnedParticipant.id,
|
|
|
|
sharedDocumentVisible: state['features/etherpad'].editing,
|
|
|
|
tileViewEnabled: state['features/video-layout'].tileViewEnabled
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sends the follow-me command, when a local property change occurs.
|
|
|
|
*
|
|
|
|
* @param {*} newSelectedValue - The changed selected value from the selector.
|
|
|
|
* @param {Object} store - The redux store.
|
|
|
|
* @private
|
|
|
|
* @returns {void}
|
|
|
|
*/
|
|
|
|
function _sendFollowMeCommand(
|
|
|
|
newSelectedValue, store) { // eslint-disable-line no-unused-vars
|
|
|
|
const state = store.getState();
|
|
|
|
const conference = getCurrentConference(state);
|
|
|
|
|
2019-04-26 18:11:53 +00:00
|
|
|
if (!conference) {
|
2019-04-17 15:05:32 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Only a moderator is allowed to send commands.
|
|
|
|
if (!isLocalParticipantModerator(state)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-04-26 18:11:53 +00:00
|
|
|
if (newSelectedValue === 'off') {
|
|
|
|
// if the change is to off, local user turned off follow me and
|
|
|
|
// we want to signal this
|
|
|
|
|
|
|
|
conference.sendCommandOnce(
|
|
|
|
FOLLOW_ME_COMMAND,
|
|
|
|
{ attributes: { off: true } }
|
|
|
|
);
|
|
|
|
|
|
|
|
return;
|
|
|
|
} else if (!state['features/base/conference'].followMeEnabled) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
conference.sendCommand(
|
2019-04-17 15:05:32 +00:00
|
|
|
FOLLOW_ME_COMMAND,
|
|
|
|
{ attributes: _getFollowMeState(state) }
|
|
|
|
);
|
|
|
|
}
|