From e6e8f621fe03b6b027197ef91fff78ed49dce2cb Mon Sep 17 00:00:00 2001 From: Leonardo Russo Date: Fri, 6 Oct 2023 13:43:35 -0300 Subject: [PATCH] fix(ios): resuming video ad after closing the in-app browser on iOS (#3275) --- API.md | 2 +- ios/Video/Features/RCTIMAAdsManager.swift | 9 ++++++++- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/API.md b/API.md index 7b5f099beb..67759f529e 100644 --- a/API.md +++ b/API.md @@ -667,7 +667,7 @@ Determine whether the media should played as picture in picture. * **false (default)** - Don't not play as picture in picture * **true** - Play the media as picture in picture -NOTE: Video ads cannot start when you are using the PIP on iOS (more info available at [Google IMA SDK Docs](https://developers.google.com/interactive-media-ads/docs/sdks/ios/client-side/picture_in_picture?hl=en#starting_ads)). If you are using custom controls, you must disable your PIP button when you receive the ```STARTED``` event from ```onReceiveAdEvent``` and show it again when you receive the ```ALL_ADS_COMPLETED``` event. +NOTE: Video ads cannot start when you are using the PIP on iOS (more info available at [Google IMA SDK Docs](https://developers.google.com/interactive-media-ads/docs/sdks/ios/client-side/picture_in_picture?hl=en#starting_ads)). If you are using custom controls, you must hide your PIP button when you receive the ```STARTED``` event from ```onReceiveAdEvent``` and show it again when you receive the ```ALL_ADS_COMPLETED``` event. Platforms: iOS diff --git a/ios/Video/Features/RCTIMAAdsManager.swift b/ios/Video/Features/RCTIMAAdsManager.swift index 221dff35d7..62407e74a9 100644 --- a/ios/Video/Features/RCTIMAAdsManager.swift +++ b/ios/Video/Features/RCTIMAAdsManager.swift @@ -2,7 +2,7 @@ import Foundation import GoogleInteractiveMediaAds -class RCTIMAAdsManager: NSObject, IMAAdsLoaderDelegate, IMAAdsManagerDelegate { +class RCTIMAAdsManager: NSObject, IMAAdsLoaderDelegate, IMAAdsManagerDelegate, IMALinkOpenerDelegate { private weak var _video: RCTVideo? private var _pipEnabled:() -> Bool @@ -65,6 +65,7 @@ class RCTIMAAdsManager: NSObject, IMAAdsLoaderDelegate, IMAAdsManagerDelegate { // Create ads rendering settings and tell the SDK to use the in-app browser. let adsRenderingSettings: IMAAdsRenderingSettings = IMAAdsRenderingSettings(); + adsRenderingSettings.linkOpenerDelegate = self; adsRenderingSettings.linkOpenerPresentingController = _video.reactViewController(); adsManager.initialize(with: adsRenderingSettings) @@ -125,6 +126,12 @@ class RCTIMAAdsManager: NSObject, IMAAdsLoaderDelegate, IMAAdsManagerDelegate { _video?.setPaused(false) } + // MARK: - IMALinkOpenerDelegate + + func linkOpenerDidClose(inAppLink linkOpener: NSObject) { + adsManager?.resume() + } + // MARK: - Helpers func convertEventToString(event: IMAAdEventType!) -> String {