2017-09-27 03:18:08 +00:00
|
|
|
/* @flow */
|
|
|
|
|
2017-08-18 11:30:30 +00:00
|
|
|
import { VIDEO_MUTISM_AUTHORITY } from './constants';
|
|
|
|
|
2016-10-05 14:36:59 +00:00
|
|
|
/**
|
2017-09-27 03:18:08 +00:00
|
|
|
* Determines whether video is currently muted by the audio-only authority.
|
2016-10-05 14:36:59 +00:00
|
|
|
*
|
2017-09-27 03:18:08 +00:00
|
|
|
* @param {Store} store - The redux store.
|
|
|
|
* @returns {boolean}
|
2016-10-05 14:36:59 +00:00
|
|
|
*/
|
2017-09-27 03:18:08 +00:00
|
|
|
export function isVideoMutedByAudioOnly(store: { getState: Function }) {
|
|
|
|
return _isVideoMutedByAuthority(store, VIDEO_MUTISM_AUTHORITY.AUDIO_ONLY);
|
2016-10-05 14:36:59 +00:00
|
|
|
}
|
2017-08-18 11:30:30 +00:00
|
|
|
|
2017-09-08 09:26:54 +00:00
|
|
|
/**
|
2017-09-27 03:18:08 +00:00
|
|
|
* Determines whether video is currently muted by a specific
|
|
|
|
* <tt>VIDEO_MUTISM_AUTHORITY</tt>.
|
2017-09-08 09:26:54 +00:00
|
|
|
*
|
2017-09-27 03:18:08 +00:00
|
|
|
* @param {Store} store - The redux store.
|
|
|
|
* @param {number} videoMutismAuthority - The <tt>VIDEO_MUTISM_AUTHORITY</tt>
|
|
|
|
* which is to be checked whether it has muted video.
|
|
|
|
* @returns {boolean} If video is currently muted by the specified
|
|
|
|
* <tt>videoMutismAuthority</tt>, then <tt>true</tt>; otherwise, <tt>false</tt>.
|
2017-09-08 09:26:54 +00:00
|
|
|
*/
|
2017-09-27 03:18:08 +00:00
|
|
|
function _isVideoMutedByAuthority(
|
|
|
|
{ getState }: { getState: Function },
|
|
|
|
videoMutismAuthority: number) {
|
2017-09-08 09:26:54 +00:00
|
|
|
return Boolean(
|
2017-09-27 03:18:08 +00:00
|
|
|
|
|
|
|
// eslint-disable-next-line no-bitwise
|
|
|
|
getState()['features/base/media'].video.muted & videoMutismAuthority);
|
2017-09-08 09:26:54 +00:00
|
|
|
}
|
|
|
|
|
2017-08-18 11:30:30 +00:00
|
|
|
/**
|
2017-09-27 03:18:08 +00:00
|
|
|
* Determines whether video is currently muted by the user authority.
|
2017-08-18 11:30:30 +00:00
|
|
|
*
|
2017-09-27 03:18:08 +00:00
|
|
|
* @param {Store} store - The redux store.
|
2017-08-18 11:30:30 +00:00
|
|
|
* @returns {boolean}
|
|
|
|
*/
|
2017-09-27 03:18:08 +00:00
|
|
|
export function isVideoMutedByUser(store: { getState: Function }) {
|
|
|
|
return _isVideoMutedByAuthority(store, VIDEO_MUTISM_AUTHORITY.USER);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determines whether a specific videoTrack should be rendered.
|
|
|
|
*
|
|
|
|
* @param {Track} videoTrack - The video track which is to be rendered.
|
|
|
|
* @param {boolean} waitForVideoStarted - True if the specified videoTrack
|
|
|
|
* should be rendered only after its associated video has started;
|
|
|
|
* otherwise, false.
|
|
|
|
* @returns {boolean} True if the specified videoTrack should be renderd;
|
|
|
|
* otherwise, false.
|
|
|
|
*/
|
|
|
|
export function shouldRenderVideoTrack(
|
|
|
|
videoTrack: { muted: boolean, videoStarted: boolean },
|
|
|
|
waitForVideoStarted: boolean) {
|
|
|
|
return (
|
|
|
|
videoTrack
|
|
|
|
&& !videoTrack.muted
|
|
|
|
&& (!waitForVideoStarted || videoTrack.videoStarted));
|
2017-08-18 11:30:30 +00:00
|
|
|
}
|