From c7f185e9e08aaf395fecbc9859bb6375d60e8950 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=81lvaro=20Velad=20Galv=C3=A1n?= Date: Thu, 28 Sep 2023 11:31:02 +0200 Subject: [PATCH] feat(UI): Add config to preferDocumentPictureInPicture (#5690) Closes https://github.com/shaka-project/shaka-player/issues/5689 --- ui/controls.js | 9 ++++++--- ui/externs/ui.js | 9 ++++++++- ui/ui.js | 1 + 3 files changed, 15 insertions(+), 4 deletions(-) diff --git a/ui/controls.js b/ui/controls.js index 2761268938..14806f7f59 100644 --- a/ui/controls.js +++ b/ui/controls.js @@ -648,7 +648,8 @@ shaka.ui.Controls = class extends shaka.util.FakeEventTarget { * @export */ isPiPAllowed() { - if ('documentPictureInPicture' in window) { + if ('documentPictureInPicture' in window && + this.config_.preferDocumentPictureInPicture) { return true; } if (document.pictureInPictureEnabled) { @@ -663,7 +664,8 @@ shaka.ui.Controls = class extends shaka.util.FakeEventTarget { * @export */ isPiPEnabled() { - if ('documentPictureInPicture' in window) { + if ('documentPictureInPicture' in window && + this.config_.preferDocumentPictureInPicture) { return !!window.documentPictureInPicture.window; } else { return !!document.pictureInPictureElement; @@ -673,7 +675,8 @@ shaka.ui.Controls = class extends shaka.util.FakeEventTarget { /** @export */ async togglePiP() { try { - if ('documentPictureInPicture' in window) { + if ('documentPictureInPicture' in window && + this.config_.preferDocumentPictureInPicture) { await this.toggleDocumentPictureInPicture_(); } else if (!document.pictureInPictureElement) { // If you were fullscreen, leave fullscreen first. diff --git a/ui/externs/ui.js b/ui/externs/ui.js index 4999add000..f41e35864f 100644 --- a/ui/externs/ui.js +++ b/ui/externs/ui.js @@ -87,7 +87,8 @@ shaka.extern.UIVolumeBarColors; * enableTooltips: boolean, * keyboardSeekDistance: number, * keyboardLargeSeekDistance: number, - * fullScreenElement: HTMLElement + * fullScreenElement: HTMLElement, + * preferDocumentPictureInPicture: boolean * }} * * @property {!Array.} controlPanelElements @@ -193,6 +194,12 @@ shaka.extern.UIVolumeBarColors; * @property {HTMLElement} fullScreenElement * DOM element on which fullscreen will be done. * Defaults to Shaka Player Container. + * @property {boolean} preferDocumentPictureInPicture + * Indicates whether the Document Picture in Picture API is preferred or the + * Video Element Picture in Picture API is preferred. + * Changing this property in mid-playback may produce undesired behavior if + * you are already in PiP. + * Defaults to true. * @exportDoc */ shaka.extern.UIConfiguration; diff --git a/ui/ui.js b/ui/ui.js index f6599e3e2b..3a0476d9f8 100644 --- a/ui/ui.js +++ b/ui/ui.js @@ -245,6 +245,7 @@ shaka.ui.Overlay = class { keyboardSeekDistance: 5, keyboardLargeSeekDistance: 60, fullScreenElement: this.videoContainer_, + preferDocumentPictureInPicture: true, }; // eslint-disable-next-line no-restricted-syntax