diff --git a/src/js/player.js b/src/js/player.js index 5790d04ad6..2ee68836df 100644 --- a/src/js/player.js +++ b/src/js/player.js @@ -359,6 +359,8 @@ class Player extends Component { this.boundHandleTechTouchEnd_ = (e) => this.handleTechTouchEnd_(e); this.boundHandleTechTap_ = (e) => this.handleTechTap_(e); + this.boundUpdatePlayerHeightOnAudioOnlyMode_ = (e) => this.updatePlayerHeightOnAudioOnlyMode_(e); + // default isFullscreen_ to false this.isFullscreen_ = false; @@ -395,6 +397,7 @@ class Player extends Component { // Init state audioOnlyCache_ this.audioOnlyCache_ = { + controlBarHeight: null, playerHeight: null, hiddenChildren: [] }; @@ -4483,6 +4486,17 @@ class Player extends Component { return !!this.isAudio_; } + updatePlayerHeightOnAudioOnlyMode_() { + const controlBar = this.getChild('ControlBar'); + + if (!controlBar || this.audioOnlyCache_.controlBarHeight === controlBar.currentHeight()) { + return; + } + + this.audioOnlyCache_.controlBarHeight = controlBar.currentHeight(); + this.height(this.audioOnlyCache_.controlBarHeight); + } + enableAudioOnlyUI_() { // Update styling immediately to show the control bar so we can get its height this.addClass('vjs-audio-only-mode'); @@ -4506,6 +4520,9 @@ class Player extends Component { }); this.audioOnlyCache_.playerHeight = this.currentHeight(); + this.audioOnlyCache_.controlBarHeight = controlBarHeight; + + this.on('playerresize', this.boundUpdatePlayerHeightOnAudioOnlyMode_); // Set the player height the same as the control bar this.height(controlBarHeight); @@ -4514,6 +4531,7 @@ class Player extends Component { disableAudioOnlyUI_() { this.removeClass('vjs-audio-only-mode'); + this.off('playerresize', this.boundUpdatePlayerHeightOnAudioOnlyMode_); // Show player components that were previously hidden this.audioOnlyCache_.hiddenChildren.forEach(child => child.show()); diff --git a/test/unit/player.test.js b/test/unit/player.test.js index 4feb3ea34b..c7d440a5d5 100644 --- a/test/unit/player.test.js +++ b/test/unit/player.test.js @@ -3323,6 +3323,33 @@ QUnit.test('turning on audioPosterMode when audioOnlyMode is already on will tur }); }); +QUnit.test('player height should match control bar height when audioOnlyMode is enabled', function(assert) { + const player = TestHelpers.makePlayer({ responsive: true, width: 320, height: 240 }); + + player.trigger('ready'); + + player.audioOnlyMode(true).then(() => { + const initialPlayerHeight = player.currentHeight(); + + player.width(768); + player.el().style.fontSize = '20px'; + player.trigger('playerresize'); + + assert.ok(initialPlayerHeight !== player.currentHeight(), 'player height is updated'); + }) + .then(() => player.audioOnlyMode(false)) + .then(() => { + const initialPlayerHeight = player.currentHeight(); + + player.width(768); + player.el().style.fontSize = '20px'; + player.trigger('playerresize'); + + assert.equal(player.currentHeight(), initialPlayerHeight, 'player height remains unchanged'); + assert.ok(initialPlayerHeight !== player.controlBar.currentHeight(), 'player height is different from control bar height'); + }); +}); + QUnit.test('player#load resets the media element to its initial state', function(assert) { const player = TestHelpers.makePlayer({});