From 59236c7034132eaa22fe0f86da8f77ed08b05d58 Mon Sep 17 00:00:00 2001 From: lrusso Date: Sun, 17 Sep 2023 16:12:46 -0300 Subject: [PATCH] fix: not showing video ads in pip mode --- ios/Video/Features/RCTIMAAdsManager.swift | 7 ++++++- ios/Video/RCTVideo.swift | 14 ++++++++++++-- 2 files changed, 18 insertions(+), 3 deletions(-) diff --git a/ios/Video/Features/RCTIMAAdsManager.swift b/ios/Video/Features/RCTIMAAdsManager.swift index d069af72b6..221dff35d7 100644 --- a/ios/Video/Features/RCTIMAAdsManager.swift +++ b/ios/Video/Features/RCTIMAAdsManager.swift @@ -5,14 +5,16 @@ import GoogleInteractiveMediaAds class RCTIMAAdsManager: NSObject, IMAAdsLoaderDelegate, IMAAdsManagerDelegate { private weak var _video: RCTVideo? + private var _pipEnabled:() -> Bool /* Entry point for the SDK. Used to make ad requests. */ private var adsLoader: IMAAdsLoader! /* Main point of interaction with the SDK. Created by the SDK as the result of an ad request. */ private var adsManager: IMAAdsManager! - init(video:RCTVideo!) { + init(video:RCTVideo!, pipEnabled:@escaping () -> Bool) { _video = video + _pipEnabled = pipEnabled super.init() } @@ -86,6 +88,9 @@ class RCTIMAAdsManager: NSObject, IMAAdsLoaderDelegate, IMAAdsManagerDelegate { } // Play each ad once it has been loaded if event.type == IMAAdEventType.LOADED { + if (_pipEnabled()) { + return + } adsManager.start() } diff --git a/ios/Video/RCTVideo.swift b/ios/Video/RCTVideo.swift index 8c4dfacc37..33c72d9cad 100644 --- a/ios/Video/RCTVideo.swift +++ b/ios/Video/RCTVideo.swift @@ -65,6 +65,7 @@ class RCTVideo: UIView, RCTVideoPlayerViewControllerDelegate, RCTPlayerObserverH private var _filterName:String! private var _filterEnabled:Bool = false private var _presentingViewController:UIViewController? + private var _pictureInPictureEnabled = false /* IMA Ads */ private var _adTagUrl:String? @@ -120,10 +121,14 @@ class RCTVideo: UIView, RCTVideoPlayerViewControllerDelegate, RCTPlayerObserverH onPictureInPictureStatusChanged?([ "isActive": NSNumber(value: false)]) } + func isPipEnabled () -> Bool { + return _pictureInPictureEnabled + } + init(eventDispatcher:RCTEventDispatcher!) { super.init(frame: CGRect(x: 0, y: 0, width: 100, height: 100)) #if USE_GOOGLE_IMA - _imaAdsManager = RCTIMAAdsManager(video: self) + _imaAdsManager = RCTIMAAdsManager(video: self, pipEnabled: isPipEnabled) #endif _eventDispatcher = eventDispatcher @@ -168,7 +173,7 @@ class RCTVideo: UIView, RCTVideoPlayerViewControllerDelegate, RCTPlayerObserverH required init?(coder aDecoder: NSCoder) { super.init(coder: aDecoder) #if USE_GOOGLE_IMA - _imaAdsManager = RCTIMAAdsManager(video: self) + _imaAdsManager = RCTIMAAdsManager(video: self, pipEnabled: isPipEnabled) #endif } @@ -459,6 +464,11 @@ class RCTVideo: UIView, RCTVideoPlayerViewControllerDelegate, RCTPlayerObserverH try audioSession.setActive(true, options: []) } catch { } + if (pictureInPicture) { + _pictureInPictureEnabled = true + } else { + _pictureInPictureEnabled = false + } _pip?.setPictureInPicture(pictureInPicture) #endif }