Skip to content

Commit

Permalink
Disable PiP if subfeature is off
Browse files Browse the repository at this point in the history
  • Loading branch information
afterxleep committed Jun 17, 2024
1 parent bc42738 commit 82ad148
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 5 deletions.
4 changes: 2 additions & 2 deletions DuckDuckGo.xcodeproj/project.pbxproj
Original file line number Diff line number Diff line change
Expand Up @@ -13021,8 +13021,8 @@
isa = XCRemoteSwiftPackageReference;
repositoryURL = "https://github.com/duckduckgo/BrowserServicesKit";
requirement = {
kind = exactVersion;
version = 156.0.0;
branch = daniel/duckplayer.pip.subfeature;
kind = branch;
};
};
9FF521422BAA8FF300B9819B /* XCRemoteSwiftPackageReference "lottie-spm" */ = {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,8 @@
"kind" : "remoteSourceControl",
"location" : "https://github.com/duckduckgo/BrowserServicesKit",
"state" : {
"revision" : "e9e239fe5dfeab87dcacbf5a31c8f555623a4ce2",
"version" : "156.0.0"
"branch" : "daniel/duckplayer.pip.subfeature",
"revision" : "dfac22c6048b3d0cdda799b1b6e7b6919f24b686"
}
},
{
Expand Down
11 changes: 10 additions & 1 deletion DuckDuckGo/YoutubePlayer/DuckPlayer.swift
Original file line number Diff line number Diff line change
Expand Up @@ -115,6 +115,7 @@ final class DuckPlayer {
) {
self.preferences = preferences
isFeatureEnabled = privacyConfigurationManager.privacyConfig.isEnabled(featureKey: .duckPlayer)
isPiPFeatureEnabled = privacyConfigurationManager.privacyConfig.isSubfeatureEnabled(DuckPlayerSubfeature.pip)
mode = preferences.duckPlayerMode
bindDuckPlayerModeIfNeeded()

Expand Down Expand Up @@ -202,7 +203,14 @@ final class DuckPlayer {

@MainActor
private func encodedSettings(with webView: WKWebView?) async -> InitialSetupSettings {
let isPiPEnabled = webView?.configuration.allowsPictureInPictureMediaPlayback == true
var isPiPEnabled = webView?.configuration.allowsPictureInPictureMediaPlayback == true

// Disable WebView PiP if if the subFeature is off
if !isPiPFeatureEnabled {
webView?.configuration.allowsPictureInPictureMediaPlayback = false
isPiPEnabled = false
}

let pip = InitialSetupSettings.PIP(status: isPiPEnabled ? .enabled : .disabled)

let playerSettings = InitialSetupSettings.PlayerSettings(pip: pip)
Expand All @@ -223,6 +231,7 @@ final class DuckPlayer {
}
private var modeCancellable: AnyCancellable?
private var isFeatureEnabledCancellable: AnyCancellable?
private var isPiPFeatureEnabled: Bool

private func bindDuckPlayerModeIfNeeded() {
if isFeatureEnabled {
Expand Down

0 comments on commit 82ad148

Please sign in to comment.