1
0
mirror of https://github.com/videojs/video.js.git synced 2025-01-08 07:00:10 +02:00

fix: Don't request fullscreen from document PIP window (#8881)

## Description
Double clicking the document pip window requests fullscreen but this
fails. The gesture on the pip window can't initiate fullscreen.
Fixes #8877

## Specific Changes proposed
Change the default double click action to just exit pip. This is the
same behaviour as before without the error, as requestFullScreen() calls
exitPictureInPicture();

---------

Co-authored-by: Gary Katsevman <git@gkatsev.com>
This commit is contained in:
mister-ben 2024-10-06 07:50:03 +02:00 committed by GitHub
parent b1dee925b2
commit 077077b00a
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 21 additions and 2 deletions

View File

@ -2003,7 +2003,8 @@ class Player extends Component {
} }
/** /**
* Handle a double-click on the media element to enter/exit fullscreen * Handle a double-click on the media element to enter/exit fullscreen,
* or exit documentPictureInPicture mode
* *
* @param {Event} event * @param {Event} event
* the event that caused this function to trigger * the event that caused this function to trigger
@ -2045,7 +2046,12 @@ class Player extends Component {
) { ) {
this.options_.userActions.doubleClick.call(this, event); this.options_.userActions.doubleClick.call(this, event);
} else if (this.isInPictureInPicture() && !document.pictureInPictureElement) {
// Checking the presence of `window.documentPictureInPicture.window` complicates
// tests, checking `document.pictureInPictureElement` also works. It wouldn't
// be null in regular picture in picture.
// Exit picture in picture mode. This gesture can't trigger pip on the main window.
this.exitPictureInPicture();
} else if (this.isFullscreen()) { } else if (this.isFullscreen()) {
this.exitFullscreen(); this.exitFullscreen();
} else { } else {

View File

@ -151,6 +151,19 @@ QUnit.test('by default, double-click opens fullscreen', function(assert) {
assert.strictEqual(this.player.exitFullscreen.callCount, 1, 'has exited fullscreen'); assert.strictEqual(this.player.exitFullscreen.callCount, 1, 'has exited fullscreen');
}); });
QUnit.test('in document picture in picture mode, double-click exits pip', function(assert) {
this.player.isInPictureInPicture = () => true;
this.player.exitPictureInPicture = sinon.spy();
this.player.requestFullscreen = sinon.spy();
this.player.exitFullscreen = sinon.spy();
this.player.handleTechDoubleClick_({target: this.player.tech_.el_});
assert.strictEqual(this.player.exitPictureInPicture.callCount, 1, 'has exited pip once');
assert.strictEqual(this.player.requestFullscreen.callCount, 0, 'has not entered fullscreen');
assert.strictEqual(this.player.exitFullscreen.callCount, 0, 'has not exited fullscreen');
});
QUnit.test('when controls are disabled, double-click does nothing', function(assert) { QUnit.test('when controls are disabled, double-click does nothing', function(assert) {
let fullscreen = false; let fullscreen = false;