feat(tile-view): allow disabling thumbnail enlargement

This commit is contained in:
Jasper Hugo 2021-12-01 17:40:40 +07:00 committed by Saúl Ibarra Corretgé
parent 79b0360d2e
commit ed6f6cf766
3 changed files with 13 additions and 1 deletions

View File

@ -995,6 +995,9 @@ var config = {
// If true, tile view will not be enabled automatically when the participants count threshold is reached. // If true, tile view will not be enabled automatically when the participants count threshold is reached.
// disableTileView: true, // disableTileView: true,
// If true, the tiles will be displayed contained within the available space rather than enlarged to cover it.
// disableTileEnlargement: true,
// Controls the visibility and behavior of the top header conference info labels. // Controls the visibility and behavior of the top header conference info labels.
// If a label's id is not in any of the 2 arrays, it will not be visible at all on the header. // If a label's id is not in any of the 2 arrays, it will not be visible at all on the header.
// conferenceInfo: { // conferenceInfo: {

View File

@ -122,6 +122,7 @@ export default [
'disableSimulcast', 'disableSimulcast',
'disableThirdPartyRequests', 'disableThirdPartyRequests',
'disableTileView', 'disableTileView',
'disableTileEnlargement',
'displayJids', 'displayJids',
'doNotStoreRoom', 'doNotStoreRoom',
'doNotFlipLocalVideo', 'doNotFlipLocalVideo',

View File

@ -114,6 +114,11 @@ export type Props = {|
*/ */
_disableLocalVideoFlip: boolean, _disableLocalVideoFlip: boolean,
/**
* Indicates whether enlargement of tiles to fill the available space is disabled.
*/
_disableTileEnlargement: boolean,
/** /**
* The display mode of the thumbnail. * The display mode of the thumbnail.
*/ */
@ -548,6 +553,7 @@ class Thumbnail extends Component<Props, State> {
const { canPlayEventReceived } = this.state; const { canPlayEventReceived } = this.state;
const { const {
_currentLayout, _currentLayout,
_disableTileEnlargement,
_height, _height,
_isHidden, _isHidden,
_isScreenSharing, _isScreenSharing,
@ -581,7 +587,7 @@ class Thumbnail extends Component<Props, State> {
if (!_isScreenSharing) { if (!_isScreenSharing) {
if (canPlayEventReceived || _participant.local) { if (canPlayEventReceived || _participant.local) {
videoStyles = { videoStyles = {
objectFit: _height < 320 && tileViewActive ? 'contain' : 'cover' objectFit: (_height < 320 && tileViewActive) || _disableTileEnlargement ? 'contain' : 'cover'
}; };
} else { } else {
videoStyles = { videoStyles = {
@ -1124,6 +1130,7 @@ function _mapStateToProps(state, ownProps): Object {
startSilent, startSilent,
defaultLocalDisplayName, defaultLocalDisplayName,
disableLocalVideoFlip, disableLocalVideoFlip,
disableTileEnlargement,
iAmRecorder, iAmRecorder,
iAmSipGateway iAmSipGateway
} = state['features/base/config']; } = state['features/base/config'];
@ -1181,6 +1188,7 @@ function _mapStateToProps(state, ownProps): Object {
_currentLayout, _currentLayout,
_defaultLocalDisplayName: defaultLocalDisplayName, _defaultLocalDisplayName: defaultLocalDisplayName,
_disableLocalVideoFlip: Boolean(disableLocalVideoFlip), _disableLocalVideoFlip: Boolean(disableLocalVideoFlip),
_disableTileEnlargement: Boolean(disableTileEnlargement),
_isHidden: isLocal && iAmRecorder && !iAmSipGateway, _isHidden: isLocal && iAmRecorder && !iAmSipGateway,
_isAudioOnly: Boolean(state['features/base/audio-only'].enabled), _isAudioOnly: Boolean(state['features/base/audio-only'].enabled),
_isCurrentlyOnLargeVideo: state['features/large-video']?.participantId === id, _isCurrentlyOnLargeVideo: state['features/large-video']?.participantId === id,